Я нахожусь в JNI hell с typeconversions out wazoo:
Здесь общий поток вещей:
У GOT есть лучший способ сделать это.
Помимо всего этого дерьма, он не работает. Я возвращаю все шумы, которые, как я считаю, могут быть результатом беззнаковых коротких массивов в C (полезно для переключения бит) и подписанных коротких массивов в C. Это серьезная проблема.
Итак, я думаю, мой общий вопрос заключается в том, как я могу улучшить это, чтобы я не имел дело со всеми этими проблемами при преобразовании типов, включая проблемы с подписью/без знака.
Все, что вы можете предложить, оценят.
Я не вижу преимущества промежуточного представления short
, поскольку код Java работает с поплавками, а код C работает с удвоениями. Я бы сделал что-то вроде этого:
float[] floats = readFile();
// Convert to little-endian doubles
ByteBuffer bb = ByteBuffer.allocateDirect(4 * floats.length);
bb.order(ByteOrder.LITTLE_ENDIAN);
DoubleBuffer db = bb.asDoubleBuffer();
for (int i = 0; i < floats.length; ++ i) {
db.put(i, floats[i]);
}
doImageProcessing(bb); // Native method
// Convert double values to ARGB
int j = 0;
int[] argb = new int[floats.length / 4];
for (int i = 0; i < floats.length; i += 4) {
int a = Math.max(0, Math.min((int) (db.get(i) * 256.0), 255));
int r = Math.max(0, Math.min((int) (db.get(i+1) * 256.0), 255));
int g = Math.max(0, Math.min((int) (db.get(i+2) * 256.0), 255));
int b = Math.max(0, Math.min((int) (db.get(i+3) * 256.0), 255));
argb[j++] = (a<<24)|(r<<16)|(g<<8)|b;
}