2013-03-15 4 views
1

Я пытаюсь реализовать метод rotateBitmapCcw90, найденный по адресу another question. Чтобы использовать этот метод, я создал класс java с именем Utils. Этот класс просто:Android JNI java.lang.UnsatisfiedLinkError

package com.test.jnitest; 

import android.graphics.Bitmap; 

public class Utils { 
    static { 
     System.loadLibrary("utils"); 
    } 

    public static native Bitmap rotateBitmapCcw90(Bitmap bitmap); 
} 

rotateBitmapCcw90 реализуется внутри com_test_jnitest_Utils.cpp под poject_path/JNI. Содержание этого файла:

#include <jni.h> 
#include <android/log.h> 
#include <android/bitmap.h> 

#include <stdio.h> 
#include <stdlib.h> 

#define LOG_TAG "libutils" 
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,LOG_TAG,__VA_ARGS__) 
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,LOG_TAG,__VA_ARGS__) 
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG,__VA_ARGS__) 

extern "C" { 
JNIEXPORT jobject JNICALL Java_com_test_jnitest_Utils_rotateBitmapCcw90(JNIEnv * env, jobject obj, jobject bitmap) 
{ 
    // same code of other question 
    ... 
} 
}; 

Моего Android.mk является:

LOCAL_PATH := $(call my-dir) 

include $(CLEAR_VARS) 

LOCAL_MODULE := libutils 
LOCAL_SRC_FILES := com_test_jnitest_Utils.cpp 
LOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -llog 
LOCAL_LDLIBS += -ljnigraphics 

include $(BUILD_SHARED_LIBRARY) 

Все успешно компилируется (НКА-сборка и проект Eclipse), но как только я называю Utils.rotateBitmapCcw90 пропускания Растровое изображение, я получаю java.lang.UnsatisfiedLinkError. В журнале указано:

03-15 14:46:48.243: D/dalvikvm(1936): Trying to load lib /data/data/com.example.jnitest/lib/libutils.so 0x40f77c98 
03-15 14:46:48.253: D/dalvikvm(1936): Added shared lib /data/data/com.example.jnitest/lib/libutils.so 0x40f77c98 
03-15 14:46:48.253: D/dalvikvm(1936): No JNI_OnLoad found in /data/data/com.example.jnitest/lib/libutils.so 0x40f77c98, skipping init 
03-15 14:46:48.333: W/dalvikvm(1936): No implementation found for native Lcom/test/jnitest/Utils;.rotateBitmapCcw90:(Landroid/graphics/Bitmap;)Landroid/graphics/Bitmap; 

Quetion: что я делаю неправильно? Что-то не так с моим файлом cpp? Я также пытался создать заголовок с javah и включить его в свой cpp, но появляется та же ошибка.

ответ

1

Я, наконец, получил его для работы после смены имени lib с utils на bitmaputils.

+1

В вашем процессе уже загружен libutils.so (из/system/lib) –

0

Попытка сделать так:

import android.graphics.Bitmap; 

static { 
     System.loadLibrary("utils"); 
    } 

public class Utils { 


    public static native Bitmap rotateBitmapCcw90(Bitmap bitmap); 
} 
+0

Извините, но это не компилирует – rcdvl

0

Ваш код NDK в "com_test_jnitest_Utils.cpp", но вы добавляете "com_test_jnitest_Utils.c" в "Android.mk". Если вы измените расширение имени файла, в этой программе нет ошибки.

+0

Это была опечатка, извините. – rcdvl

0

в файле .mk должно быть так:

LOCAL_MODULE := utils 
Смежные вопросы