質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
JNI

JNI(Java Native Interface)は、Javaプラットフォームにおいて、Javaで記述されたプログラムと、他の言語で書かれたネイティブコードを連携するためのインタフェース仕様である

Xamarin

Xamarin(ザマリン)は、iPhoneなどのiOSやAndroidで動作し、C# 言語を用いてアプリを開発できるクロスプラットフォーム開発環境です。Xamarin Studioと C# 言語を用いて、 iOS と Android の両方の開発を行うことができます。

Q&A

解決済

2回答

486閲覧

XamarinからNDKを利用できるAPIレベル

otaota

総合スコア30

JNI

JNI(Java Native Interface)は、Javaプラットフォームにおいて、Javaで記述されたプログラムと、他の言語で書かれたネイティブコードを連携するためのインタフェース仕様である

Xamarin

Xamarin(ザマリン)は、iPhoneなどのiOSやAndroidで動作し、C# 言語を用いてアプリを開発できるクロスプラットフォーム開発環境です。Xamarin Studioと C# 言語を用いて、 iOS と Android の両方の開発を行うことができます。

0グッド

0クリップ

投稿2017/07/18 09:45

編集2017/07/19 05:00

###前提・実現したいこと
ここを参考に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(); } } }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

Android NDKとXamarin.Androidの組み合わせが特別に一定レベル以上のAPIを要求することはありません。そもそもXamarin.Android本体がNDKでビルドされていますし。

[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)'.

と出ているので、依存ライブラリであるところのlibsd_xxx.soがパッケージされていないのではないでしょうか。

投稿2017/07/18 12:18

atsushieno

総合スコア121

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

otaota

2017/07/19 01:06

動く端末では普通に動いているのでパッケージされてないということはないと思うのですが、 armeabiとarmeabi-v7aの2つ入れているので動く端末と動かない端末で違うものを見に行っているんでしょうか?確かにeclipseのプロジェクトの方では同時に2つは試していないので明日試して見ます。 Application.mkの中の指定をarmeabi-v7aだけにしてやってみましたが、結果は変わりませんでした。 試しに、Droid/bin/Debug/の下のxxxx-Signed.apkの拡張子をzipに変えて展開したところ、 /lib/の下に arm64-v8a armeabi armeabi-v7a x86 x86_64 というフォルダーがあり、 それぞれに libgdbserver.so libmono-profiler-log.so libmonodroid.so が入っていて、さらにarmeabi-v7aだけに libsd_xxx.so libXXX.so が入っている状況でした。
guest

0

自己解決

解決はしていないですが、原因が絞れてきたので別の質問としてあげ直しました。

投稿2017/07/19 05:39

otaota

総合スコア30

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問