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