android之 JNI端獲取並操作Surface


 1 static android::sp<android::Surface> native_surface;
2
3 static android::Surface* getNativeSurface(JNIEnv* env, jobject jsurface, jint version)
4 {
5 jclass clazz = env->FindClass("android/view/Surface");
6 jfieldID field_surface;
7 if(version <=8)
8 {
9 field_surface = env->GetFieldID(clazz, "mSurface", "I");
10 }
11 else
12 field_surface = env->GetFieldID(clazz, ANDROID_VIEW_SURFACE_JNI_ID, "I");
13
14 if (field_surface == NULL)
15 {
16 return NULL;
17 }
18 return (android::Surface *) env->GetIntField(jsurface, field_surface);
19 }
20
21 int setSurface(JNIEnv *env, jobject jsurface, jint version)
22 {
23 native_surface = getNativeSurface(env, jsurface, version);
24
25 if(android::Surface::isValid(native_surface))
26 {
27 __android_log_print(ANDROID_LOG_INFO, "libjni", "native_surface is valid");
28 return 1;
29 }
30 else
31 __android_log_print(ANDROID_LOG_ERROR, "libjni", "native_surface is invalid");
32
33 return 0;
34 }



  jsurface就是從Java端傳遞過來的,然后這里的 native_surface,就是我們想要的native surface了。為什么要 傳遞個version? 因為 android2.2以上的版本,android.view.Surface里面沒有“mSurface"了,而是用了一個常量 ANDROID_VIEW_SURFACE_JNI_ID, 區分下版本就行了。

  然后又發現jni端操作surface也是相當簡單,至少顯示圖像之類的很容易:

1 static android::Surface::SurfaceInfo info;
2 static android::Region dirtyRegion;



做下初始化:

  

dirtyRegion.set(android::Rect(0x3FFF, 0x3FFF));

 

然后

  

1 native_surface->lock(&info, &dirtyRegion, true);
2
3   memcpy(info.bits, buf, bufSize);
4
5   native_surface->unlockAndPost();

 

 
        

 

就顯示出來了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM