2013-03-15 4 views
1

another question에있는 rotateBitmapCcw90 메소드를 구현하려고합니다. 이 방법을 사용하기 위해 Utils라는 Java 클래스를 만들었습니다.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이 poject_path/JNI에서 com_test_jnitest_Utils.cpp내부에 구현 :이 클래스는 다음과 같이 간단합니다. 이 파일의 내용은 다음과 같습니다 (NDK 빌드 및 Eclipse 프로젝트)

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) 

모든 것이 성공적으로 컴파일하지만 최대한 빨리 전화로 Utils.rotateBitmapCcw90이 통과 :

#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는 비트 맵, 나는 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 is : 내가 뭘 잘못하고 있니? 내 cpp 파일에 문제가 있습니까? 나는 또한 javah로 헤더를 생성하고 그것을 내 cpp에 포함하려고 시도했지만, 같은 에러가 나타난다. 이런 식으로 일을하려고

답변

1

마지막으로 libname을 utils에서 bitmaputils로 변경 한 후 작업하게되었습니다. 당신의 .mk 파일에

+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" 에 있지만 당신은 "Android.mk"에서 "com_test_jnitest_Utils.c"를 추가합니다. 파일 이름 확장명을 변경하면이 프로그램에서 오류가 발생하지 않습니다.

+0

컴파일되지 않습니다. – rcdvl

0

은 다음과 같이해야합니다 :

LOCAL_MODULE := utils 
관련 문제