編輯:關於Android編程
1、DataProvider
package com.njupt.ndk_passdata;
public class DataProvider {
public native int add(int x,int y);
public static native int sub(int x,int y);
public native String sayHelloInC(String s);
public native int[] intMethod(int[] iNum);
public native byte[] byteMethod(byte[] iByte);
}
2、MainActivity
package com.njupt.ndk_passdata;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast;
public class MainActivity extends Activity implements OnClickListener{
static{
System.loadLibrary("Hello");
}
private Button bt1;
private Button bt2;
private Button bt3;
private Button bt4;
private DataProvider provider;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
bt1 = (Button) findViewById(R.id.bt1);
bt2 = (Button) findViewById(R.id.bt2);
bt3 = (Button) findViewById(R.id.bt3);
bt4 = (Button) findViewById(R.id.bt4);
bt1.setOnClickListener(this);
bt2.setOnClickListener(this);
bt3.setOnClickListener(this);
bt4.setOnClickListener(this);
provider = new DataProvider();
}
public void onClick(View v){
switch (v.getId()) {
case R.id.bt1:
int result = provider.add(3, 5);
Toast.makeText(this, "相加的結果: " + result, 1).show();
break;
case R.id.bt2:
String str = provider.sayHelloInC("zhangsan ");
Toast.makeText(this, str, 1).show();
break;
case R.id.bt3:
int[] arr = {1,2,3,4,5};
provider.intMethod(arr);
for(int i = 0 ; i < arr.length ; ++i){
System.out.println("java " + arr[i]);
}
break;
case R.id.bt4:
int subresult = DataProvider.sub(5, 3);
Toast.makeText(this, "相見的結果是: " + subresult, 1).show();
break;
default:
break;
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}
切換到工程的src目錄下,運行javah命令得到
3、Hello.c
#include#include #include "com_njupt_ndk_passdata_DataProvider.h" #include //include D:\android-ndk-r7b\platforms\android-8\arch-arm\usr\include\android下的log.h這個目錄 #define LOG_TAG "System.out" #define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__) #define LOGI(...) __android_log_print(ANDROID_LOG_INFO, LOG_TAG, __VA_ARGS__) /** * 返回值 char* 這個代表char數組的首地址 * Jstring2CStr 把java中的jstring的類型轉化成一個c語言中的char 字符串 */ char* Jstring2CStr(JNIEnv* env, jstring jstr) { char* rtn = NULL; jclass clsstring = (*env)->FindClass(env, "java/lang/String"); //String jstring strencode = (*env)->NewStringUTF(env, "GB2312"); // 得到一個java字符串 "GB2312" jmethodID mid = (*env)->GetMethodID(env, clsstring, "getBytes", "(Ljava/lang/String;)[B"); //[ String.getBytes("gb2312"); jbyteArray barr = (jbyteArray)(*env)->CallObjectMethod(env, jstr, mid, strencode); // String .getByte("GB2312"); jsize alen = (*env)->GetArrayLength(env, barr); // byte數組的長度 jbyte* ba = (*env)->GetByteArrayElements(env, barr, JNI_FALSE); if (alen > 0) { rtn = (char*) malloc(alen + 1); //"\0" memcpy(rtn, ba, alen); rtn[alen] = 0; } (*env)->ReleaseByteArrayElements(env, barr, ba, 0); // return rtn; } JNIEXPORT jint JNICALL Java_com_njupt_ndk_1passdata_DataProvider_add( JNIEnv * env, jobject obj, jint x, jint y) { return x+y; } /** * 代表的是調用c代碼 的class類 * jclass DataProvider 類 */ JNIEXPORT jint JNICALL Java_com_njupt_ndk_1passdata_DataProvider_sub(JNIEnv * env, jclass clazz, jint x, jint y) {//特別要注意靜態方法簽名的第二個參數.. return x-y; } JNIEXPORT jstring JNICALL Java_com_njupt_ndk_1passdata_DataProvider_sayHelloInC( JNIEnv * env, jobject obj, jstring jstr) { //在c語言中 是沒有java的String char* cstr = Jstring2CStr(env,jstr);//將java風格的字符串轉換成c風格的字符串 // c語言中的字符串 都是以'/0' 作為結尾.不加的話這個字符串的最後一位是任意字符.. char arr[] = {' ','h','e','l','l','o','\0'}; strcat(cstr,arr); return (*env)->NewStringUTF(env,cstr);//將c風格的字符轉換成java風格的字符串 } /**env java 虛擬機 結構體c實現的指針 包含的有很多jni方法 *jobject obj 代表的是調用這個c代碼的java對象 代表的是DataProider的對象 */ JNIEXPORT jintArray JNICALL Java_com_njupt_ndk_1passdata_DataProvider_intMethod( JNIEnv * env, jobject obj, jintArray arr) { /** * 要操作數組的必要條件: * 1、知道數組的長度 * 2、操作數組中的每一個元素 */ int len = (*env)->GetArrayLength(env,arr);//返還這個數組的長度.. LOGD("shuzu len =%d",len); jint* intarr = (*env)->GetIntArrayElements(env,arr,0); int i; for(i = 0 ; i < len ; ++i){ LOGD("intarr[%d]=%d", i, intarr[i]); intarr[i] += 10; } return arr; } JNIEXPORT jbyteArray JNICALL Java_com_njupt_ndk_1passdata_DataProvider_byteMethod( JNIEnv * env, jobject obj, jbyteArray bytearr) { }
4、Android.mk
LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := Hello LOCAL_SRC_FILES := Hello.c LOCAL_LDLIBS += -llog include $(BUILD_SHARED_LIBRARY)
5、main.xml

canvas的常見用法
Canvascanvas是一種抽象概念,是2D圖形系統中的重要部分,canvas一系列函數最終都是android 2D圖形庫Skia的一些列封裝,對應在SKCanvas.
Android開發工具----Android Studio調試技巧
0.前言Android Studio目前已經成為開發Android的主要工具,作為開發者,調試、發現並解決BUG是家常便飯。正所謂,工欲善其事必先利其器,今天我們就來看看
Android之日期及時間選擇對話框用法實例分析
本文實例講述了Android之日期及時間選擇對話框用法。分享給大家供大家參考。具體如下:清單文件:<?xml version=1.0 encoding=ut
Dialog在android中的應用(一)
如果做一個如下圖的Dialog,首先要定義樣式: stateUnchanged|adjustResize @null @null