【问题标题】:Android NokiaX Emulator Google Maps, MapActivity, error opening trace file: No such file or directoryAndroid NokiaX Emulator Google Maps, MapActivity, error opening trace file: No such file or directory
【发布时间】:2014-05-03 00:56:49
【问题描述】:

我正在尝试将我的 Android 项目 carEgiri 移植到 NokiaX。我遇到了这个异常

05-02 04:57:19.989: E/Trace(1928): error opening trace file: No such file or directory (2)
05-02 04:57:19.989: E/AndroidRuntime(1928): FATAL EXCEPTION: main
05-02 04:57:19.989: E/AndroidRuntime(1928): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.mcruiseon.pune.nokiax.caregiri/com.mcruiseon.caregiri.Registration}: java.lang.RuntimeException: stub
05-02 04:57:19.989: E/AndroidRuntime(1928):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1991)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2092)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at android.app.ActivityThread.access$600(ActivityThread.java:133)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1203)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at android.os.Handler.dispatchMessage(Handler.java:99)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at android.os.Looper.loop(Looper.java:137)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at android.app.ActivityThread.main(ActivityThread.java:4807)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at java.lang.reflect.Method.invokeNative(Native Method)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at java.lang.reflect.Method.invoke(Method.java:511)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:792)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:559)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at dalvik.system.NativeStart.main(Native Method)
05-02 04:57:19.989: E/AndroidRuntime(1928): Caused by: java.lang.RuntimeException: stub
05-02 04:57:19.989: E/AndroidRuntime(1928):     at com.google.android.maps.MapActivity.<init>(Unknown Source)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at com.mcruiseon.caregiri.Registration.<init>(Registration.java:48)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at java.lang.Class.newInstanceImpl(Native Method)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at java.lang.Class.newInstance(Class.java:1319)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at android.app.Instrumentation.newActivity(Instrumentation.java:1068)
05-02 04:57:19.989: E/AndroidRuntime(1928):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1982)
05-02 04:57:19.989: E/AndroidRuntime(1928):     ... 11 more
05-02 04:57:22.790: E/SWIPE(1078): clear()

清单文件有(相关部分)

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

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

        <uses-library
            android:name="com.here.android"
            android:required="false" />

        <meta-data
            android:name="com.here.android.maps.appid"
            android:value="code" />
        <meta-data
            android:name="com.here.android.maps.apptoken"
            android:value="code" />

        <activity
            android:name="com.mcruiseon.caregiri.Registration"
            android:label="@string/app_name"
            android:screenOrientation="portrait"
            android:theme="@android:style/Theme.Translucent.NoTitleBar"
            android:windowSoftInputMode="adjustPan" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>

            <meta-data
                android:name="isCarEgiri"
                android:value="true" />
        </activity>

我的代码使用 MapActivity,

  • 我是否需要重写一些代码以不使用 MapActivity(来自 com.google.android.maps),而是使用这里的 api 的?
  • 我的模拟器目前使用 4.1.2 Nokia X 作为目标。
  • 如果我取消注释,应用程序将无法安装

    -->

这意味着诺基亚模拟器支持 com.google.android.maps,API。

【问题讨论】:

    标签: android android-emulator nokiax


    【解决方案1】:

    我正在查看 android sdk 文件夹(附加文件夹)上的诺基亚 sdk 更新。我想知道为什么 com.google.android.maps.jar 作为诺基亚 SDK 的一部分提供。凭直觉,我让我的项目使用诺基亚 X 4.1.2(设置-Android),仅将 com.google.android.maps.jar 复制到我项目的 libs 文件夹中。在我的清单文件中初始化 here 映射。现在应用程序加载。

    我崩溃了,我用谷歌搜索发现http://developer.nokia.com/community/discussion/showthread.php/245545-Porting-Google-Maps-v2-to-HERE-Maps-gt-Error-initializing-map-problem-with-disk-cach

    现在,我的应用可以运行了。

    无需使用 HERE MAPS 库,带有 reference_v2 导入的 google api 应该可以工作。

    【讨论】:

    • 您提供的链接是针对 Google v2 地图的,据我所知,com.google.android.maps 命名空间将指示 Google v1 使用 insetad。
    【解决方案2】:

    基本上有两种方法可以将您的 Google Maps v1 应用程序移植到使用 HERE 地图。

    1. 通过使用 HERE Wrapper 库提供与 google 相同的命名空间实现,Steps for porting are explained in the documentation。这将生成一个只能在诺基亚 X 设备上运行的新 APK

    2. 通过使用 HERE Wrapper 库,该库在 nokia-namespace 下提供,部分为 documented in the documentation,例如 at Github

    2 选项的步骤通常是:

    1. 修改 Manifest 文件以包含所有 HERE 必需的内容(有关详细信息,请参阅选项 1 文档,请记住仅将谷歌地图的必需标志设置为 false,但仍保留这些行)

    2. 将库添加到您的项目中(从 gi​​thub 获取)

    3. 复制与 google maps 一起使用的布局,重命名,然后将所有 google 命名空间项替换为使用 nokia namespece。请记得更改任何 ID。

    4. 使用 Google 地图复制该类的 java 实现,重命名它,并将所有 google 导入替换为 nokia-namespace 导入,还要记住将布局更改为使用第 3 步中的布局。

    5. 实施运行时逻辑以选择使用哪些地图产品。它的示例显示在docs

    然后,选项 2 将创建 APK,您可以在 Nokia X 设备以及支持 Google maps v1 的其他设备上运行它。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2012-06-03
      • 2022-07-11
      • 2023-04-03
      • 2017-02-08
      • 2019-07-23
      • 2018-11-22
      • 2014-01-20
      • 1970-01-01
      相关资源
      最近更新 更多