2013-03-15 120 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 
相关问题