You've already forked lazarus-ccr
Now the JNI example actually works
git-svn-id: https://svn.code.sf.net/p/lazarus-ccr/svn@2167 8e941d3f-bd1b-0410-a28a-d453659cc2b4
This commit is contained in:
@ -10,7 +10,7 @@ uses
|
|||||||
const curClass:JClass=nil;
|
const curClass:JClass=nil;
|
||||||
nativeCodeLoaded:JfieldID=nil;
|
nativeCodeLoaded:JfieldID=nil;
|
||||||
|
|
||||||
function Java_com_bero_nativetest_Main_stringFromJNI(env:PJNIEnv;this:jobject):jstring; cdecl;
|
function Java_com_pascal_jnitest_AndroidJNITest_stringFromJNI(env:PJNIEnv;this:jobject):jstring; cdecl;
|
||||||
var x:single;
|
var x:single;
|
||||||
begin
|
begin
|
||||||
__android_log_write(ANDROID_LOG_INFO,'nativetest','Java_com_bero_nativetest_Main_stringFromJNI entered');
|
__android_log_write(ANDROID_LOG_INFO,'nativetest','Java_com_bero_nativetest_Main_stringFromJNI entered');
|
||||||
@ -20,16 +20,24 @@ begin
|
|||||||
__android_log_write(ANDROID_LOG_INFO,'nativetest','Java_com_bero_nativetest_Main_stringFromJNI exited');
|
__android_log_write(ANDROID_LOG_INFO,'nativetest','Java_com_bero_nativetest_Main_stringFromJNI exited');
|
||||||
end;
|
end;
|
||||||
|
|
||||||
const NativeMethods:array[0..0] of JNINativeMethod=
|
function Java_com_pascal_jnitest_AndroidJNITest_intFromJNI(env:PJNIEnv;this:jobject): jint; cdecl;
|
||||||
|
begin
|
||||||
|
Result := 8;
|
||||||
|
end;
|
||||||
|
|
||||||
|
const NativeMethods:array[0..1] of JNINativeMethod=
|
||||||
((name:'stringFromJNI';
|
((name:'stringFromJNI';
|
||||||
signature:'()Ljava/lang/String;';
|
signature:'()Ljava/lang/String;';
|
||||||
fnPtr:@Java_com_bero_nativetest_Main_stringFromJNI;));
|
fnPtr:@Java_com_pascal_jnitest_AndroidJNITest_stringFromJNI;),
|
||||||
|
(name:'intFromJNI';
|
||||||
|
signature:'()I';
|
||||||
|
fnPtr:@Java_com_pascal_jnitest_AndroidJNITest_intFromJNI;));
|
||||||
|
|
||||||
function JNI_OnLoad(vm:PJavaVM;reserved:pointer):jint; cdecl;
|
function JNI_OnLoad(vm:PJavaVM;reserved:pointer):jint; cdecl;
|
||||||
begin
|
begin
|
||||||
curVM:=vm;
|
curVM:=vm;
|
||||||
__android_log_write(ANDROID_LOG_INFO,'nativetest','JNI_OnLoad called');
|
__android_log_write(ANDROID_LOG_INFO,'nativetest','JNI_OnLoad called');
|
||||||
__android_log_write(ANDROID_LOG_INFO,'nativetest',PChar(Format('CurVM=%x', [PtrInt(CurVM)])));
|
(* __android_log_write(ANDROID_LOG_INFO,'nativetest',PChar(Format('CurVM=%x', [PtrInt(CurVM)])));
|
||||||
if curVM^.GetEnv(curVM,@curEnv,JNI_VERSION_1_6)<>JNI_OK then begin
|
if curVM^.GetEnv(curVM,@curEnv,JNI_VERSION_1_6)<>JNI_OK then begin
|
||||||
__android_log_write(ANDROID_LOG_FATAL,'nativetest','curVM^.GetEnv failed');
|
__android_log_write(ANDROID_LOG_FATAL,'nativetest','curVM^.GetEnv failed');
|
||||||
result:=JNI_ERR;
|
result:=JNI_ERR;
|
||||||
@ -54,7 +62,7 @@ begin
|
|||||||
__android_log_write(ANDROID_LOG_FATAL,'nativetest','curEnv^.GetFieldID failed');
|
__android_log_write(ANDROID_LOG_FATAL,'nativetest','curEnv^.GetFieldID failed');
|
||||||
result:=JNI_ERR;
|
result:=JNI_ERR;
|
||||||
exit;
|
exit;
|
||||||
end;
|
end;*)
|
||||||
|
|
||||||
result:=JNI_VERSION_1_6;
|
result:=JNI_VERSION_1_6;
|
||||||
end;
|
end;
|
||||||
@ -63,9 +71,11 @@ procedure JNI_OnUnload(vm:PJavaVM;reserved:pointer); cdecl;
|
|||||||
begin
|
begin
|
||||||
end;
|
end;
|
||||||
|
|
||||||
exports JNI_OnLoad name 'JNI_OnLoad',
|
exports
|
||||||
JNI_OnUnload name 'JNI_OnUnload',
|
JNI_OnLoad name 'JNI_OnLoad',
|
||||||
Java_com_bero_nativetest_Main_stringFromJNI name 'Java_com_bero_nativetest_Main_stringFromJNI';
|
JNI_OnUnload name 'JNI_OnUnload',
|
||||||
|
Java_com_pascal_jnitest_AndroidJNITest_stringFromJNI name 'Java_com_pascal_jnitest_AndroidJNITest_stringFromJNI',
|
||||||
|
Java_com_pascal_jnitest_AndroidJNITest_intFromJNI name 'Java_com_pascal_jnitest_AndroidJNITest_intFromJNI';
|
||||||
|
|
||||||
begin
|
begin
|
||||||
end.
|
end.
|
||||||
|
@ -12,11 +12,12 @@ public class AndroidJNITest extends Activity {
|
|||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
TextView tv = new TextView(this);
|
TextView tv = new TextView(this);
|
||||||
tv.setText( stringFromJNI() );
|
tv.setText( Integer.toString(intFromJNI()) );
|
||||||
setContentView(tv);
|
setContentView(tv);
|
||||||
}
|
}
|
||||||
|
|
||||||
public native String stringFromJNI();
|
public native String stringFromJNI();
|
||||||
|
public native int intFromJNI();
|
||||||
|
|
||||||
public long nativeCodeLoaded=0;
|
public long nativeCodeLoaded=0;
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user