Update Region.cpp to use AParcel NDK APIs
Test: CtsGraphicsTestCases
Bug: 145227478
Change-Id: I36f5d3e760bce3c302277c7897c7f8df0ac3cb61
diff --git a/libs/hwui/Android.bp b/libs/hwui/Android.bp
index 1715a27..973f857 100644
--- a/libs/hwui/Android.bp
+++ b/libs/hwui/Android.bp
@@ -288,7 +288,6 @@
"jni/PathEffect.cpp",
"jni/PathMeasure.cpp",
"jni/Picture.cpp",
- "jni/Region.cpp",
"jni/Shader.cpp",
"jni/Typeface.cpp",
"jni/Utils.cpp",
@@ -334,6 +333,7 @@
"jni/GraphicsStatsService.cpp",
"jni/Movie.cpp",
"jni/MovieImpl.cpp",
+ "jni/Region.cpp", // requires libbinder_ndk
"jni/pdf/PdfDocument.cpp",
"jni/pdf/PdfEditor.cpp",
"jni/pdf/PdfRenderer.cpp",
@@ -341,6 +341,7 @@
],
shared_libs: [
"libandroidfw",
+ "libbinder_ndk",
"libmediandk",
"libnativedisplay",
"libnativewindow",
diff --git a/libs/hwui/jni/Region.cpp b/libs/hwui/jni/Region.cpp
index c95bcea..1e064b8 100644
--- a/libs/hwui/jni/Region.cpp
+++ b/libs/hwui/jni/Region.cpp
@@ -19,10 +19,10 @@
#include "GraphicsJNI.h"
#ifdef __ANDROID__ // Layoutlib does not support parcel
-#include <binder/Parcel.h>
+#include <android/binder_parcel.h>
+#include <android/binder_parcel_jni.h>
+#include <android/binder_parcel_utils.h>
#endif
-#include "android_os_Parcel.h"
-#include "android_util_Binder.h"
namespace android {
@@ -207,10 +207,11 @@
return 0;
}
- android::Parcel* p = android::parcelForJavaObject(env, parcel);
-
std::vector<int32_t> rects;
- p->readInt32Vector(&rects);
+
+ AParcel* p = AParcel_fromJavaParcel(env, parcel);
+ ndk::AParcel_readVector(p, &rects);
+ AParcel_delete(p);
if ((rects.size() % 4) != 0) {
return 0;
@@ -235,8 +236,6 @@
return JNI_FALSE;
}
- android::Parcel* p = android::parcelForJavaObject(env, parcel);
-
std::vector<int32_t> rects;
SkRegion::Iterator it(*region);
while (!it.done()) {
@@ -248,7 +247,10 @@
it.next();
}
- p->writeInt32Vector(rects);
+ AParcel* p = AParcel_fromJavaParcel(env, parcel);
+ ndk::AParcel_writeVector(p, rects);
+ AParcel_delete(p);
+
return JNI_TRUE;
#else
return JNI_FALSE;