2013-03-15 114 views
1

我想實現方法rotateBitmapCcw90找到another question。 爲了使用這種方法,我創建了一個名爲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。這個文件的內容是:

#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) 

一切編譯成功(NDK構建和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; 

排隊是:我做錯了什麼?我的cpp文件有什麼問題嗎?我也已經試着用javah生成一個頭文件並將其包含在我的cpp中,但是同樣的錯誤出現了。

回答

1

我終於在將lib名稱從utils改爲bitmaputils後得到了它的工作。

+1

您的進程已經加載了libutils.so(從/ system/lib) – 2013-03-17 18:51:11

0

試圖這樣做:

import android.graphics.Bitmap; 

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

public class Utils { 


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

對不起,但這並不編譯 – rcdvl 2013-03-15 19:31:56

0

你的NDK代碼是 「com_test_jnitest_Utils.cpp」, 但你添加 「com_test_jnitest_Utils.c」 在 「Android.mk」。 如果您更改文件擴展名,則此程序中無錯誤。

+0

這是一個錯字,對不起。 – rcdvl 2013-03-16 14:22:06

0

.mk文件應該是這樣的:

LOCAL_MODULE := utils 
相關問題