我正在尝试实现另一个问题中找到的方法 rotateBitmapCcw90 。为了使用这种方法,我创建了一个名为 Utils 的 java 类。这个类很简单:
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-build 和 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 中,但出现了相同的错误。