###前提・実現したいこと
ここを参考にXamarin(Android)のプロジェクトの中にjniフォルダーを作り、自作のc++の関数や既存のsoファイル内の関数を呼ぶ関数をc#から呼ぶようにしています。普段テストで使っている端末では問題なく使えていたので安心していたのですが、いざ他の端末でテストしようとしたところことごとく関数呼び出しのタイミングでエラーで弾かれてしまいました。
法則性としては、
Android OSのバージョンが4.4.2以上のものなら大丈夫な気がしていますが、それ以下の端末が弾かれているようです。
これはここに書いてあるようにproject.propertiesの中で
target=android-19
と指定しているので納得できたのですが、ここを
target=android-16
と書き換えても現象は変わりませんでした。
古いバージョンのOSでも正常に動くようにするにはどうすれば良いでしょうか?
###発生している問題・エラーメッセージ
ログをみると、期待通り動いている端末では、DllImportの時に5箇所くらい別の場所を探しに行って失敗したあとに見付てくれているようですが、
[Mono] DllImport attempting to load: 'XXX'. [Mono] DllImport error loading library '/storage/emulated/0/Android/data/jp.co.yyyyy.zzzzz/files/.__override__/libXXX': 'dlopen failed: library "/data/app/jp.co.yyyyy.zzzzz-1/lib/arm//storage/emulated/0/Android/data/jp.co.yyyyy.zzzzz/files/.__override__/libXXX" not found'. [Mono] DllImport error loading library '/storage/emulated/0/Android/data/jp.co.yyyyy.zzzzz/files/.__override__/libXXX.so': 'dlopen failed: library "/data/app/jp.co.yyyyy.zzzzz-1/lib/arm//storage/emulated/0/Android/data/jp.co.yyyyy.zzzzz/files/.__override__/libXXX.so" not found'. [Mono] DllImport error loading library '/system/lib/libXXX': 'dlopen failed: library "/data/app/jp.co.yyyyy.zzzzz-1/lib/arm//system/lib/libXXX" not found'. [Mono] DllImport error loading library '/system/lib/libXXX.so': 'dlopen failed: library "/data/app/jp.co.yyyyy.zzzzz-1/lib/arm//system/lib/libXXX.so" not found'. [Mono] DllImport error loading library 'libXXX': 'dlopen failed: library "/data/app/jp.co.yyyyy.zzzzz-1/lib/arm/libXXX" not found'. [Mono] DllImport loaded library 'libXXX.so'. [Mono] DllImport searching in: 'XXX' ('libXXX.so').
エラーが出る端末では、同じタイミングで別のsoファイル(既存のsoファイル)が読み込めないと言っているように見えます。
[Mono] DllImport attempting to load: 'XXX'. [Mono] DllImport error loading library '/storage/sdcard0/Android/data/jp.co.yyyyy.zzzzz/files/.__override__/libXXX': 'Cannot load library: load_library[1093]: Library '/data/data/jp.co.yyyyy.zzzzz/lib//storage/sdcard0/Android/data/jp.co.yyyyy.zzzzz/files/.__override__/libXXX' not found'. [Mono] DllImport error loading library '/storage/sdcard0/Android/data/jp.co.yyyyy.zzzzz/files/.__override__/libXXX.so': 'Cannot load library: load_library[1093]: Library '/data/data/jp.co.yyyyy.zzzzz/lib//storage/sdcard0/Android/data/jp.co.yyyyy.zzzzz/files/.__override__/libXXX.so' not found'. [Mono] DllImport error loading library '/system/lib/libXXX': 'Cannot load library: load_library[1093]: Library '/data/data/jp.co.yyyyy.zzzzz/lib//system/lib/libXXX' not found'. [Mono] DllImport error loading library '/system/lib/libXXX.so': 'Cannot load library: load_library[1093]: Library '/data/data/jp.co.yyyyy.zzzzz/lib//system/lib/libXXX.so' not found'. [Mono] DllImport error loading library 'libXXX': 'Cannot load library: load_library[1093]: Library '/data/data/jp.co.yyyyy.zzzzz/lib/libXXX' not found'. [Mono] DllImport error loading library 'libXXX.so': 'Cannot load library: link_image[1891]: 216 could not load needed library 'libsd_xxx.so' for 'libXXX.so' (load_library[1093]: Library 'libsd_xxx.so' not found)'. [Mono] DllImport error loading library 'XXX': 'Cannot load library: load_library[1093]: Library '/data/data/jp.co.yyyyy.zzzzz/lib/XXX' not found'. [Mono] DllImport error loading library '/storage/sdcard0/Android/data/jp.co.yyyyy.zzzzz/files/.__override__/libXXX': 'Cannot load library: load_library[1093]: Library '/data/data/jp.co.yyyyy.zzzzz/lib//storage/sdcard0/Android/data/jp.co.yyyyy.zzzzz/files/.__override__/libXXX' not found'. [Mono] DllImport error loading library '/storage/sdcard0/Android/data/jp.co.yyyyy.zzzzz/files/.__override__/libXXX.so': 'Cannot load library: find_library[1201]: 216 'libXXX.so' failed to load previously'. [Mono] DllImport error loading library '/system/lib/libXXX': 'Cannot load library: load_library[1093]: Library '/data/data/jp.co.yyyyy.zzzzz/lib//system/lib/libXXX' not found'. [Mono] DllImport error loading library '/system/lib/libXXX.so': 'Cannot load library: find_library[1201]: 216 'libXXX.so' failed to load previously'. [Mono] DllImport error loading library 'libXXX': 'Cannot load library: load_library[1093]: Library '/data/data/jp.co.yyyyy.zzzzz/lib/libXXX' not found'. [Mono] DllImport error loading library 'libXXX.so': 'Cannot load library: find_library[1201]: 216 'libXXX.so' failed to load previously'. [Mono] DllImport error loading library 'libXXX': 'Cannot load library: load_library[1093]: Library '/data/data/jp.co.yyyyy.zzzzz/lib/libXXX' not found'. [Mono] DllImport unable to load library 'Cannot load library: load_library[1093]: Library '/data/data/jp.co.yyyyy.zzzzz/lib/libXXX' not found'.
###該当のソースコード
念のため、Android.mkとApplication.mkを貼っておきます。
LOCAL_PATH := $(call my-dir) # libxxx用 include $(CLEAR_VARS) LOCAL_MODULE := prebuild-libsd_xxx LOCAL_SRC_FILES := lib/libsd_xxx.so #include $(PREBUILT_STATIC_LIBRARY) include $(PREBUILT_SHARED_LIBRARY) include $(CLEAR_VARS) LOCAL_MODULE := XXX LOCAL_SRC_FILES := XXX.cpp #LOCAL_LDLIBS := -landroid -llog LOCAL_LDLIBS := -llog LOCAL_SHARED_LIBRARIES := prebuild-libsd_xxx include $(BUILD_SHARED_LIBRARY)
APP_ABI := armeabi armeabi-v7a
この結果、Droidフォルダーのすぐ下のlibs/armeabi-v7aとlibs/armeabi
に、libsd_xxx.soとlibXXX.soが配置されています。
###試したこと
eclipseでJava + JNIで同じ既存のsoファイルを使用したときは、
Android OSのバージョンが4.1.2でも動くことは確認しています。
(ちなみに、そのときは、armeabi-v7aだけで動いていました)
※既存のsoファイル自身は2.3.3以上で動くとドキュメントに書かれています。
###補足情報(言語/FW/ツール等のバージョンなど)
Xamarin 6.3(build 864)
Mac Note Pro
OS X Yosemite(10.10.5)
###追記
実際に呼び出しているところのコードも貼り付けておきます。
XXXPage.cs
namespace XaXXXXX { public class XXXPage : ContentPage { public XXXPage() { Content = new StackLayout { Children = { // 省略 } }; Appearing += (sender, e) => { XXXInit();//呼び出し元 }; this.Disappearing += (sender, e) => { XXXTerm(); }; } void XXXInit() { DependencyService.Get<IMisc>().XXXInit(); } void XXXTerm() { DependencyService.Get<IMisc>().XXXTerm(); } } }
iMisc.cs
using System; namespace XaXXXXX { public interface IMisc { void XXXInit(); void XXXTerm(); } }
Droid/Misc.cs
[assembly: Xamarin.Forms.Dependency(typeof(Misc))] namespace XaXXXXX.Droid { public class Misc : IMisc { [DllImport("XXX")] public static extern void XXXinitialize(); [DllImport("XXX")] public static extern int XXXterminate(); public void XXXInit() { XXXinitialize(device, ver, false); // libsd_xxx.so内の関数 } public void XXXTerm() { XXXterminate(); } } }
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/07/19 01:06