2

Jake Wharton のActionBarSherlockActionBarSherlock-Plugin-Mapsで使用するサンプル プロジェクトをセットアップしようとしています。ここここの指示に従います。Fragments は必ずしも必要ではありません。これが私が作成した単純なクラスです。

package com.example.actionbarsherlock;

import android.os.Bundle;
import com.actionbarsherlock.app.SherlockMapActivity;

public class MainActivity extends SherlockMapActivity {

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    @Override
    protected boolean isRouteDisplayed() {
        return false;
    }
}

正確な説明に従おうとしましたがClassNotFoundException、アプリケーションを起動すると、. ここにスタックトレースがあります。

  Unable to resolve superclass of Lcom/actionbarsherlock/app/SherlockMapActivity; (729)
  Link of class 'Lcom/actionbarsherlock/app/SherlockMapActivity;' failed
  Unable to resolve superclass of Lcom/example/actionbarsherlock/MainActivity; (533)
  Link of class 'Lcom/example/actionbarsherlock/MainActivity;' failed
 D/AndroidRuntime(408): Shutting down VM
  threadid=3: thread exiting with uncaught exception (group=0x4001b188)
  Uncaught handler: thread main exiting due to uncaught exception

  java.lang.RuntimeException: Unable to instantiate activity 
    ComponentInfo{com.example.actionbarsherlock/com.example.actionbarsherlock.MainActivity}: 
    java.lang.ClassNotFoundException: com.example.actionbarsherlock.MainActivity
    in loader dalvik.system.PathClassLoader@44e8ca40

    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2417)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
    at android.app.ActivityThread.access$2200(ActivityThread.java:119)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
    at android.os.Handler.dispatchMessage(Handler.java:99)
    at android.os.Looper.loop(Looper.java:123)
    at android.app.ActivityThread.main(ActivityThread.java:4363)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:521)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
    at dalvik.system.NativeStart.main(Native Method)

  Caused by: java.lang.ClassNotFoundException: com.example.actionbarsherlock.MainActivity 
    in loader dalvik.system.PathClassLoader@44e8ca40

    at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
    at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2409)
    ... 11 more
  threadid=7: reacting to signal 3
  Unable to open stack trace file '/data/anr/traces.txt': Permission denied

以前にライブラリをテストし、正常に機能するサブクラスを作成しましたSherlockActivity。そうこうしているうちに、 の設定ClassNotFoundExceptionを忘れてしまうと同じことが起こることに気がつきました。念のため、(と) の両方のサンプル プロジェクトのファイルを次に示します。android:themeAndroidManifest.xmlSherlockActivitySherlockMapActivity

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.actionbarsherlock"
    android:versionCode="1"
    android:versionName="1.0" >
    <uses-sdk
        android:minSdkVersion="7"
        android:targetSdkVersion="15" />
    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:theme="@style/Theme.Sherlock"
            android:name=".MainActivity"
            android:label="@string/title_activity_main" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>
</manifest> 

アップデート:

uses-libraryRaghav Sood と M Mohsin Naeem の提案に従って設定を追加すると、次のメッセージが表示されます。

Installation error: INSTALL_FAILED_MISSING_SHARED_LIBRARY

これが私のプロジェクトのセットアップのスクリーンショットです。

パッケージ エクスプローラー


編集:

私のactionbarsherlocktest.classpathプロジェクトのファイルが役立つかもしれませ ん...

<?xml version="1.0" encoding="UTF-8"?>
<classpath>
    <classpathentry kind="src" path="src"/>
    <classpathentry kind="src" path="gen"/>
    <classpathentry kind="con" path="com.android.ide.eclipse.adt.ANDROID_FRAMEWORK"/>
    <classpathentry kind="con" path="com.android.ide.eclipse.adt.LIBRARIES"/>
    <classpathentry kind="lib" path="libs/actionbarsherlock-plugin-maps-4.1.0.jar"/>
    <classpathentry kind="output" path="bin/classes"/>
</classpath>

ライブラリプロジェクトの.classpathファイルはまったく同じように見えます。


INSTALL_FAILED_MISSING_SHARED_LIBRARYエラー メッセージの解決策

何らかの理由で、Eclipse は常に、API レベル 7 用に構成されているがGoogle API なしで構成されたエミュレーターを開始しました。「マップ対応」エミュレーターを強制的に選択することはできませんでした。「マップレス」エミュレーターを削除した後、アプリケーションは正常に起動しました。これがどのように起こるか知っていますか?


概要:

最後に、私はそれを実行しました。ここに私が共有したいいくつかの経験があります。

  • Web サイトからActionBarSherlockの最新バージョンをダウンロードします。
  • 4.1.0 タグ (9598f2b) をチェックアウトするためにリポジトリを複製しないでください。私にはうまくいきませんでした。
  • Eclipse で ActionBarSherlock ライブラリ プロジェクトをセットアップします。
  • 含まaction-support-v4.jarれている を最新バージョンに更新します。
  • ライブラリプロジェクトのフォルダに追加しactionbarsherlock-plugin-map-x.y.z.jarます。libs
  • ライブラリ プロジェクトのビルド パスに追加する必要はありません。
  • メイン プロジェクトをセットアップし、ライブラリ プロジェクトを依存関係として追加します。
  • メイン プロジェクトにまたはを追加する必要はありません。また、メイン プロジェクトのビルド パスに .jar ファイルを追加する必要もありません。action-support-v4.jaractionbarsherlock-plugin-map-x.y.z.jar
  • 従うべき単純で役立つ例は、リポジトリにあります。
4

2 に答える 2

10

このエラーが発生する理由は 3 つだけです。

  1. クラスは本当に存在しません。公式の例のコードを使用してこれを取得している場合は、ライブラリの最新のビルドがあることを確認してください。
  2. jar をビルド パスに追加していません。これを修正するには、Eclipse で jar を右クリックし、[ビルド パス] ► [ビルド パスに追加] を実行します。
  3. jar が /libs フォルダーにありません。これは、ビルド パスに jar を追加したときに発生しますが、新しいバージョンの ADT では /libs にある必要があります。そこに置き、ビルドパスに再度追加します。

また、追加する必要があります

<uses-library android:name="com.google.android.maps" />

マニフェスト ファイルに。

于 2012-07-18T16:27:12.390 に答える
3

このステップ 8 を見逃しています

<uses-library android:name="com.google.android.maps" />

これをマニフェスト ファイルに追加する必要があります。

このようにしてください

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.actionbarsherlock"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
    android:minSdkVersion="7"
    android:targetSdkVersion="15" />
<application
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <uses-library android:name="com.google.android.maps" />
    <activity
        android:theme="@style/Theme.Sherlock"
        android:name=".MainActivity"
        android:label="@string/title_activity_main" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

于 2012-07-18T16:25:38.560 に答える