2017-10-15 10 views
0

Android StudioでUnityアプリケーションのAndroidプラグインを開発しています。このプラグインは、Google Fit APIにアクセスし、Unityアプリケーションに表示できる情報を提供することを目指しています。私はこのポストの最後に私のJavaファイルと私のGradleファイルとManifestファイルを含めました。UnityプラグインのNoClassDefFoundErrorとClassNotFoundException

logInUnity()方法が適切に呼び出されます

package com.kasperiekqvist.player; 

import android.Manifest; 
import android.content.Intent; 
import android.content.pm.PackageManager; 
import android.os.Bundle; 
import android.support.v4.app.ActivityCompat; 

import com.google.android.gms.common.api.GoogleApiClient; 
import com.unity3d.player.UnityPlayer; 

import java.text.SimpleDateFormat; 
import java.util.Date; 

public class UnityPlayerActivity extends com.unity3d.player.UnityPlayerActivity { 

    private GoogleApiClient mClient = null; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     logInUnity("onCreate", null); 
     super.onCreate(savedInstanceState); 
     checkPermissions(); 
    } 

    /* SNIP */ 

    private boolean checkPermissions() { 
     int permissionState = ActivityCompat.checkSelfPermission(this, 
       Manifest.permission.ACCESS_FINE_LOCATION); 
     boolean hasPermission = permissionState == PackageManager.PERMISSION_GRANTED; 
     logInUnity("checkPermissions", new String[] { "ACCESS_FINE_LOCATION:" + hasPermission }); 
     return hasPermission; 
    } 

    private void logInUnity(String methodName, String[] linesToLog) { 
     if(methodName != null) { 
      String message = "UnityPlayerActivity:" + methodName + " was called at "; 
      message += new SimpleDateFormat("MM-dd HH:mm:ss").format(new Date()); 
      if(linesToLog != null) { 
        for(int i = 0; i < linesToLog.length; i++) { 
         message += ";" + linesToLog[i]; 
        } 
      } 
      UnityPlayer.UnitySendMessage("JavaCallback", "LogInUnity", message); 
     } 
    } 
} 

UnityPlayerActivity.javaファイル。私のメソッドを使用して私のLogInUnity()メソッド内のものを私のC#スクリプトでロギングしています。 adb logcat -s Unity delvikvm DEBUGコマンドを使用すると、コマンドプロンプトですべてを見ることができます。

問題はAndroidサポートライブラリにアクセスしていることです。私のcheckPermissionsメソッドでActivityCompat.checkSelfPermission()と呼ぶと、私のアクティビティはすぐに強制終了します。私は以下のクラッシュ情報を掲載しました。

クラッシュ情報

10-15 19:57:53.843 18197 18197 E AndroidRuntime: FATAL EXCEPTION: main 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: Process: com.kasperiekqvist.androidpluginproject, PID: 18197 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: java.lang.Error: FATAL EXCEPTION [main] 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: Unity version  : 2017.2.0f3 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: Device model  : OnePlus ONEPLUS A5000 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: Device fingerprint: OnePlus/OnePlus5/OnePlus5:7.1.1/NMF26X/09131759:user/release-keys 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: Caused by: java.lang.NoClassDefFoundError: Failed resolution of: Landroid/support/v4/app/ActivityCompat; 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at com.kasperiekqvist.player.UnityPlayerActivity.checkPermissions(UnityPlayerActivity.java:74) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at com.kasperiekqvist.player.UnityPlayerActivity.onCreate(UnityPlayerActivity.java:27) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at android.app.Activity.performCreate(Activity.java:6743) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1134) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2715) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2848) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at android.app.ActivityThread.-wrap12(ActivityThread.java) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1552) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:102) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at android.os.Looper.loop(Looper.java:154) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:6334) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: Caused by: java.lang.ClassNotFoundException: Didn't find class "android.support.v4.app.ActivityCompat" on path: DexPathList[[zip file "/data/app/com.kasperiekqvist.androidpluginproject-2/base.apk"],nativeLibraryDirectories=[/data/app/com.kasperiekqvist.androidpluginproject-2/lib/arm, /data/app/com.kasperiekqvist.androidpluginproject-2/base.apk!/lib/armeabi-v7a, /system/lib, /vendor/lib]] 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at java.lang.ClassLoader.loadClass(ClassLoader.java:380) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: at java.lang.ClassLoader.loadClass(ClassLoader.java:312) 
10-15 19:57:53.843 18197 18197 E AndroidRuntime: ... 14 more 
10-15 19:57:53.843 18197 18197 D AppTracker: App Event: crash 
10-15 19:57:53.846 1804 16770 W ActivityManager: Force finishing activity com.kasperiekqvist.androidpluginproject/com.kasperiekqvist.player.UnityPlayerActivity 
10-15 19:57:53.848 1804 16770 D ActivityTrigger: ActivityTrigger activityPauseTrigger 
10-15 19:57:53.849 18197 18197 I Process : Sending signal. PID: 18197 SIG: 9 
10-15 19:57:53.851 4741 6303 D OPReportService: addMonitorFolder onEvent [email protected]_57_53_851.txt, event:128 
10-15 19:57:53.860 1804 4733 D EmbryoManager: prepare com.kasperiekqvist.androidpluginproject 
10-15 19:57:53.860 1804 4733 I ActivityManager: Process com.kasperiekqvist.androidpluginproject (pid 18197) has died 
10-15 19:57:53.860 1804 4733 D ActivityManager: get process top duration : com.kasperiekqvist.androidpluginproject, duration : 45 
10-15 19:57:53.860 1804 4733 D ActivityManager: cleanUpApplicationRecord -- 18197 

私は私のGradleファイルの依存関係にcompile 'com.android.support:support-v4:25.3.1'が含まれています。私が行った研究によると、問題はAndroid Support Libraryがjarファイルに含まれていないということです。しかし、私はそれについて間違っている可能性があります。

それにもかかわらず、私は試してみることが不足しています。 Stack Overflowで同じエラーが発生したのと同じような多くの問題を発見しました。これらの質問の答えに示された多くのことを使って問題を解決しようとしました。しかし、これまでのところ誰も働いていません。

明確にするために、ActivityCompat.checkSelfPermission()メソッド呼び出しを追加する前に、すべてが正しく機能していました。したがって、問題はサポートライブラリにある必要があります。

build.gradleファイル

apply plugin: 'com.android.library' 

android { 
    compileSdkVersion 25 
    buildToolsVersion "26.0.2" 

    defaultConfig { 
     minSdkVersion 16 
     targetSdkVersion 25 
     versionCode 1 
     versionName "1.0" 

     testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" 

    } 
    buildTypes { 
     release { 
      minifyEnabled false 
      proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 
     } 
    } 
} 

dependencies { 
    compile fileTree(dir: 'libs', include: ['*.jar']) 
    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', { 
     exclude group: 'com.android.support', module: 'support-annotations' 
    }) 
    compile 'com.android.support:appcompat-v7:25.3.1' 
    testCompile 'junit:junit:4.12' 
    compile 'com.google.android.gms:play-services-fitness:11.0.4' 
    compile 'com.android.support:support-v4:25.3.1' 
} 

のAndroidManifest.xml私はPlay Services Resolver for Unityを使って、私の問題を解決するために管理

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.kasperiekqvist.androidpluginproject" xmlns:tools="http://schemas.android.com/tools" android:versionName="1.0" android:versionCode="1" android:installLocation="preferExternal"> 
    <supports-screens android:smallScreens="true" android:normalScreens="true" android:largeScreens="true" android:xlargeScreens="true" android:anyDensity="true" /> 
    <application android:theme="@style/UnityThemeSelector" android:icon="@drawable/app_icon" android:label="@string/app_name" android:debuggable="false" android:isGame="true" android:banner="@drawable/app_banner"> 
    <activity android:name="com.kasperiekqvist.player.UnityPlayerActivity" android:label="@string/app_name" android:screenOrientation="fullSensor" android:launchMode="singleTask" android:configChanges="mcc|mnc|locale|touchscreen|keyboard|keyboardHidden|navigation|orientation|screenLayout|uiMode|screenSize|smallestScreenSize|fontScale|layoutDirection|density"> 
     <intent-filter> 
     <action android:name="android.intent.action.MAIN" /> 
     <category android:name="android.intent.category.LAUNCHER" /> 
     <category android:name="android.intent.category.LEANBACK_LAUNCHER" /> 
     </intent-filter> 
     <meta-data android:name="unityplayer.UnityActivity" android:value="true" /> 
    </activity> 
    <meta-data android:name="unity.build-id" android:value="c9792a78-0123-4f4b-be86-1b85de56f689" /> 
    <meta-data android:name="unity.splash-mode" android:value="0" /> 
    <meta-data android:name="unity.splash-enable" android:value="True" /> 
    <meta-data android:name="android.max_aspect" android:value="2.1" /> 
    </application> 
    <uses-sdk android:minSdkVersion="16" android:targetSdkVersion="25" /> 
    <uses-feature android:glEsVersion="0x00020000" /> 
    <uses-feature android:name="android.hardware.vulkan" android:required="false" /> 
    <uses-feature android:name="android.hardware.touchscreen" android:required="false" /> 
    <uses-feature android:name="android.hardware.touchscreen.multitouch" android:required="false" /> 
    <uses-feature android:name="android.hardware.touchscreen.multitouch.distinct" android:required="false" /> 
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/> 
</manifest> 
+3

可能な重複:これと明示的にアプリにACCESS_FINE_LOCATION許可を与えた後、私はすべてが機能するようになりましたことを証明した私のコマンドプロンプトで次のような出力を得ることができた後

NoClassDefFoundError in Java?](https://stackoverflow.com/questions/34413/why-am-i-getting-a-noclassdeffounderror-in-java) –

+0

私はその質問に対する答えで自分の問題を解決できませんでした。しかし、私はそれが不可能ではないと主張していない。私は自分の解決策を見つけ、それを以下に含めました。 – Kasperi

答えて

0

ファイル。

enter image description here

:私のプロジェクトファイルはこのように見てしまった、リゾルバはその仕事をした後

<dependencies> 
    <androidPackages> 
    <androidPackage spec="com.android.support:support-v4:25.3.1"> 
     <androidSdkPackageIds> 
     <androidSdkPackageId>extras-android-m2repository</androidSdkPackageId> 
     </androidSdkPackageIds> 
     <repositories> 
     <repository>https://maven.google.com</repository> 
     </repositories> 
    </androidPackage> 
    </androidPackages> 
</dependencies> 

:私はREADME.mdファイルで説明する手順に従って、次の内容の*Dependencies.xmlファイルが含まれて

Android SDKフォルダの下にあるファイルからこれらのファイルをインポートするだけで十分だったのだろうか。私はすでにsupport-v4-25.3.1を含むように試みたと思うが、何らかの理由で私はそれが動作していないことを覚えている。[なぜ私が取得していますの

10-15 23:43:26.574 3438 3693 I Unity : UnityPlayerActivity:checkPermissions was called at 10-15 23:43:23 
10-15 23:43:26.574 3438 3693 I Unity : ACCESS_FINE_LOCATION:true 
10-15 23:43:26.574 3438 3693 I Unity : 
10-15 23:43:26.574 3438 3693 I Unity : (Filename: ./artifacts/generated/common/runtime/DebugBindings.gen.cpp Line: 51) 
10-15 23:43:26.574 3438 3693 I Unity :