Update Region.cpp to use AParcel NDK APIs

Test: CtsGraphicsTestCases
Bug: 145227478
Change-Id: I36f5d3e760bce3c302277c7897c7f8df0ac3cb61
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;