From c5cf762177c5708a5efa39f95b086c751e03e2e4 Mon Sep 17 00:00:00 2001 From: Hal Canary Date: Fri, 2 Mar 2018 17:28:39 -0500 Subject: Viewer/Amdroid: universal build, resources in APK Change-Id: I57dda6e3329dbee720333b6e92142fce28f8dbd3 Reviewed-on: https://skia-review.googlesource.com/111940 Commit-Queue: Hal Canary Reviewed-by: Florin Malita Reviewed-by: Yuqian Li --- tools/sk_app/android/surface_glue_android.cpp | 31 ++++++++++++++++++++++++++- 1 file changed, 30 insertions(+), 1 deletion(-) (limited to 'tools/sk_app') diff --git a/tools/sk_app/android/surface_glue_android.cpp b/tools/sk_app/android/surface_glue_android.cpp index 9c734247db..9766d3a56d 100644 --- a/tools/sk_app/android/surface_glue_android.cpp +++ b/tools/sk_app/android/surface_glue_android.cpp @@ -13,18 +13,44 @@ #include #include +#include +#include #include #include #include #include #include "../Application.h" +#include "ResourceFactory.h" #include "SkTypes.h" #include "SkUtils.h" #include "Window_android.h" + namespace sk_app { +static void config_resource_mgr(JNIEnv* env, jobject assetManager) { + static AAssetManager* gAAssetManager = nullptr; + SkASSERT(assetManager); + gAAssetManager = AAssetManager_fromJava(env, assetManager); + SkASSERT(gAAssetManager); + gResourceFactory = [](const char* resource) -> sk_sp { + if (!gAAssetManager) { + return nullptr; + } + SkString path = SkStringPrintf("resources/%s", resource); + AAsset* asset = AAssetManager_open(gAAssetManager, path.c_str(), AASSET_MODE_STREAMING); + if (!asset) { + return nullptr; + } + size_t size = SkToSizeT(AAsset_getLength(asset)); + sk_sp data = SkData::MakeUninitialized(size); + (void)AAsset_read(asset, data->writable_data(), size); + AAsset_close(asset); + return data; + }; +} + static const int LOOPER_ID_MESSAGEPIPE = 1; static const std::unordered_map ANDROID_TO_WINDOW_KEYMAP({ @@ -208,7 +234,10 @@ void* SkiaAndroidApp::pthread_main(void* arg) { extern "C" // extern "C" is needed for JNI (although the method itself is in C++) JNIEXPORT jlong JNICALL - Java_org_skia_viewer_ViewerApplication_createNativeApp(JNIEnv* env, jobject application) { + Java_org_skia_viewer_ViewerApplication_createNativeApp(JNIEnv* env, + jobject application, + jobject assetManager) { + config_resource_mgr(env, assetManager); SkiaAndroidApp* skiaAndroidApp = new SkiaAndroidApp(env, application); return (jlong)((size_t)skiaAndroidApp); } -- cgit v1.2.3