7

私はAndroid開発に不慣れです:)

シンプルなアプリを作成しようとしています。地図を使ったアクティビティです。HTC 1xをコンピューターに接続しましたが、(intellij IDEA経由で)アプリを実行しようとするとクラッシュします。

ネット(およびstackoverflow)で手がかりを検索しましたが、見つかりませんでした。次に例を示します。
 - GoogleMapsv2-
エラー-googlemap  - runtimeexception-クラスフラグメントの拡張エラー

理由を教えていただけますか?

ありがとう、

オメル



技術の詳細:

HTC1xはandroid4.1.1を実行します
プロジェクト外部ライブラリ:
 -Android 4.0 Google API
 -Android-サポート-V4.jar
 --google-play-services.jar



メインActivity.xml:

<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
              android:layout_width = "fill_parent"
              android:layout_height = "fill_parent">
<fragment xmlns:android = "http://schemas.android.com/apk/res/android"
          android:id = "@ + id / map"
          android:layout_width = "match_parent"
          android:layout_height = "match_parent"
          android:name = "com.google.android.gms.maps.SupportMapFragment" />
</ LinearLayout>



主なアクティビティ.Java

パッケージcom.example.mapTest;

android.os.Bundleをインポートします。
import android.support.v4.app.FragmentActivity;

パブリッククラスMainActivityはFragmentActivityを拡張します{
    / **
     *アクティビティが最初に作成されたときに呼び出されます。
     * /
    @オーバーライド
    public void onCreate(Bundle savedInstanceState){
        super.onCreate(savedInstanceState);
        setContentView(R.layout.mainActivity);
    }
}



Manifest.xml

<?xml version = "1.0" encoding = "utf-8"?>
<マニフェストxmlns:android = "http://schemas.android.com/apk/res/android"
          package = "com.example.mapTest"
          android:versionCode = "1"
          android:versionName = "1.0">

    <uses-sdk android:minSdkVersion = "14" android:targetSdkVersion = "14" />

    <用途-機能
            android:glEsVersion = "0x00020000"
            android:required = "true" />

    <許可
            android:name = "com.example.mapTest.permission.MAPS_RECEIVE"
            android:protectionLevel = "signature" />
    <uses-permission android:name = "com.example.mapTest.permission.MAPS_RECEIVE" />

    <uses-permission android:name = "android.permission.INTERNET" />
    <uses-permission android:name = "android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name = "android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name = "com.google.android.providers.gsf.permission.READ_GSERVICES" />
    <uses-permission android:name = "android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name = "android.permission.ACCESS_FINE_LOCATION" />

    <application android:label = "@ string / app_name" android:icon = "@ drawable / ic_launcher">

        <メタデータ
                android:name = "com.google.android.maps.v2.API_KEY"
                android:value = "AIzaSyAEHaDozQSyWTXl77MpGp6Wtvd5RyteV8Q" />

        <activity android:name = "MainActivity"
                  android:label = "@ string / app_name">
            <インテントフィルター>
                <action android:name = "android.intent.action.MAIN" />
                <category android:name = "android.intent.category.LAUNCHER" />
            </ intent-filter>
        </ activity>
    </アプリケーション>
</マニフェスト>



例外:

03-19 00:09:30.325:ERROR / NotificationService(434):icon == 0の通知を無視します:Notification(pri = 0 contentView = null vibrate = null sound = nullnull defaults = 0x0 flags = 0x62 kind = [null])
03-19 00:09:41.430:エラー/ MediaScannerService(13421):例外スキャンファイル
        android.os.DeadObjectException
        android.os.BinderProxy.transact(ネイティブメソッド)で
        android.media.IMediaScannerListener $ Stub $ Proxy.scanCompleted(IMediaScannerListener.java:100)で
        com.android.providers.media.MediaScannerService $ ServiceHandler.handleMessage(MediaScannerService.java:1007)で
        android.os.Handler.dispatchMessage(Handler.java:99)で
        android.os.Looper.loop(Looper.java:155)で
        com.android.providers.media.MediaScannerService.run(MediaScannerService.java:713)で
        java.lang.Thread.run(Thread.java:864)で
03-19 00:09:48.655:ERROR / ExternalAccountType(31657):サポートされていない属性readOnly
03-19 00:09:48.900:ERROR / ExternalAccountType(31657):サポートされていない属性readOnly
03-19 00:09:51.965:ERROR / EmbeddedLogger(434):アプリがクラッシュしました!プロセス:com.example.mapTest
03-19 00:09:51.965:ERROR / EmbeddedLogger(434):アプリがクラッシュしました!パッケージ:com.example.mapTest v1(1.0)
03-19 00:09:51.965:ERROR / EmbeddedLogger(434):アプリケーションラベル:mapTest
03-19 00:09:51.965:エラー/ AndroidRuntime(22403):致命的な例外:メイン
        java.lang.NoClassDefFoundError:com.google.android.gms.R $ styleable
        com.google.android.gms.maps.GoogleMapOptions.createFromAttributes(不明なソース)で
        com.google.android.gms.maps.SupportMapFragment.onInflate(不明なソース)で
        android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:279)で
        android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:676)で
        android.view.LayoutInflater.rInflate(LayoutInflater.java:746)で
        android.view.LayoutInflater.inflate(LayoutInflater.java:489)で
        android.view.LayoutInflater.inflate(LayoutInflater.java:396)で
        android.view.LayoutInflater.inflate(LayoutInflater.java:352)で
        com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:365)で
        android.app.Activity.setContentView(Activity.java:1912)で
        com.example.mapTest.MainActivity.onCreate(MainActivity.java:13)で
        android.app.Activity.performCreate(Activity.java:5066)で
        android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1101)で
        android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2307)で
        android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387)で
        android.app.ActivityThread.access $ 600(ActivityThread.java:151)で
        android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1331)で
        android.os.Handler.dispatchMessage(Handler.java:99)で
        android.os.Looper.loop(Looper.java:155)で
        android.app.ActivityThread.main(ActivityThread.java:5485)で
        java.lang.reflect.Method.invokeNative(ネイティブメソッド)で
        java.lang.reflect.Method.invoke(Method.java:511)で
        com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:1028)で
        com.android.internal.os.ZygoteInit.main(ZygoteInit.java:795)で
        dalvik.system.NativeStart.main(ネイティブメソッド)で
03-19 00:09:53.785:エラー/ MediaScannerService(13421):例外スキャンファイル
        android.os.DeadObjectException
        android.os.BinderProxy.transact(ネイティブメソッド)で
        android.media.IMediaScannerListener $ Stub $ Proxy.scanCompleted(IMediaScannerListener.java:100)で
        com.android.providers.media.MediaScannerService $ ServiceHandler.handleMessage(MediaScannerService.java:1007)で
        android.os.Handler.dispatchMessage(Handler.java:99)で
        android.os.Looper.loop(Looper.java:155)で
        com.android.providers.media.MediaScannerService.run(MediaScannerService.java:713)で
        java.lang.Thread.run(Thread.java:864)で
03-19 00:09:54.365:ERROR / NotificationService(434):icon == 0の通知を無視します:Notification(pri = 0 contentView = null vibrate = null sound = nullnull defaults = 0x0 flags = 0x62 kind = [null])
03-19 00:10:03.075:エラー/外部アカウントタイプ(31657):サポートされていない属性readOnly
03-19 00:10:03.380:ERROR / NotificationService(434):icon == 0の通知を無視します:Notification(pri = 0 contentView = null vibrate = null sound = nullnull defaults = 0x0 flags = 0x62 kind = [null])
03-19 00:10:03.960:エラー/外部アカウントタイプ(31657):サポートされていない属性readOnly
03-19 00:10:08.200:エラー/ MediaScannerService(13421):例外スキャンファイル
        android.os.DeadObjectException
        android.os.BinderProxy.transact(ネイティブメソッド)で
        android.media.IMediaScannerListener $ Stub $ Proxy.scanCompleted(IMediaScannerListener.java:100)で
        com.android.providers.media.MediaScannerService $ ServiceHandler.handleMessage(MediaScannerService.java:1007)で
        android.os.Handler.dispatchMessage(Handler.java:99)で
        android.os.Looper.loop(Looper.java:155)で
        com.android.providers.media.MediaScannerService.run(MediaScannerService.java:713)で
        java.lang.Thread.run(Thread.java:864)で
03-19 00:10:10.270:エラー/ AndroidRuntime(23231):致命的な例外:メイン
        java.lang.NoClassDefFoundError:com.google.android.gms.R $ styleable
        com.google.android.gms.maps.GoogleMapOptions.createFromAttributes(不明なソース)で
        com.google.android.gms.maps.SupportMapFragment.onInflate(不明なソース)で
        android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:279)で
        android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:676)で
        android.view.LayoutInflater.rInflate(LayoutInflater.java:746)で
        android.view.LayoutInflater.inflate(LayoutInflater.java:489)で
        android.view.LayoutInflater.inflate(LayoutInflater.java:396)で
        android.view.LayoutInflater.inflate(LayoutInflater.java:352)で
        com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:365)で
        android.app.Activity.setContentView(Activity.java:1912)で
        com.example.mapTest.MainActivity.onCreate(MainActivity.java:13)で
        android.app.Activity.performCreate(Activity.java:5066)で
        android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1101)で
        android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2307)で
        android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387)で
        android.app.ActivityThread.access $ 600(ActivityThread.java:151)で
        android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1331)で
        android.os.Handler.dispatchMessage(Handler.java:99)で
        android.os.Looper.loop(Looper.java:155)で
        android.app.ActivityThread.main(ActivityThread.java:5485)で
        java.lang.reflect.Method.invokeNative(ネイティブメソッド)で
        java.lang.reflect.Method.invoke(Method.java:511)で
        com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:1028)で
        com.android.internal.os.ZygoteInit.main(ZygoteInit.java:795)で
        dalvik.system.NativeStart.main(ネイティブメソッド)で
03-19 00:10:10.285:ERROR / EmbeddedLogger(434):アプリがクラッシュしました!プロセス:com.example.mapTest
03-19 00:10:10.285:ERROR / EmbeddedLogger(434):アプリがクラッシュしました!パッケージ:com.example.mapTest v1(1.0)
03-19 00:10:10.285:ERROR / EmbeddedLogger(434):アプリケーションラベル:mapTest
4

1 に答える 1

1

プロジェクトにGooglePlayサービスライブラリを含めましたか?それがないと、重要なリソースを利用できません。詳細については、質問:java.lang.noclassdeffounderror:com.google.android.gms.R$styleableを参照してください。

于 2013-03-18T22:29:12.977 に答える