have you declared this activity in your AndroidManifest.xml?

 

I/ActivityManager( 1128): Displayed com.android.settings/.WirelessSettings: +1s116ms

I/ActivityManager( 1128): Starting: Intent { act=android.intent.action.MAIN cmp=com.rockchip.ethernetsettings/.EthernetSettings } from pid 2371

D/AndroidRuntime( 2371): Shutting down VM

W/dalvikvm( 2371): threadid=1: thread exiting with uncaught exception (group=0xa00194f0)

E/AndroidRuntime( 2371): FATAL EXCEPTION: main

E/AndroidRuntime( 2371): android.content.ActivityNotFoundException: Unable to find explicit activity class {com.rockchip.ethernetsettings/com.rockchip.ethernetsettings.EthernetSettings}; have you declared this activity in your AndroidManifest.xml?

E/AndroidRuntime( 2371):     at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:1404)

E/AndroidRuntime( 2371):     at android.app.Instrumentation.execStartActivity(Instrumentation.java:1378)

E/AndroidRuntime( 2371):     at android.app.Activity.startActivityForResult(Activity.java:2827)

E/AndroidRuntime( 2371):     at android.app.Activity.startActivity(Activity.java:2933)

E/AndroidRuntime( 2371):     at android.preference.Preference.performClick(Preference.java:828)

E/AndroidRuntime( 2371):     at android.preference.PreferenceScreen.onItemClick(PreferenceScreen.java:190)

E/AndroidRuntime( 2371):     at android.widget.AdapterView.performItemClick(AdapterView.java:284)

E/AndroidRuntime( 2371):     at android.widget.ListView.performItemClick(ListView.java:3513)

E/AndroidRuntime( 2371):     at android.widget.AbsListView$PerformClick.run(AbsListView.java:1800)

E/AndroidRuntime( 2371):     at android.os.Handler.handleCallback(Handler.java:587)

E/AndroidRuntime( 2371):     at android.os.Handler.dispatchMessage(Handler.java:92)

E/AndroidRuntime( 2371):     at android.os.Looper.loop(Looper.java:123)

E/AndroidRuntime( 2371):     at android.app.ActivityThread.main(ActivityThread.java:3647)

E/AndroidRuntime( 2371):     at java.lang.reflect.Method.invokeNative(Native Method)

E/AndroidRuntime( 2371):     at java.lang.reflect.Method.invoke(Method.java:507)

E/AndroidRuntime( 2371):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)

E/AndroidRuntime( 2371):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)

E/AndroidRuntime( 2371):     at dalvik.system.NativeStart.main(Native Method)

W/ActivityManager( 1128): Force finishing activity com.android.settings/.WirelessSettings

W/ActivityManager( 1128): Activity pause timeout for HistoryRecord{a0674e28 com.android.settings/.WirelessSettings}

D/dalvikvm( 1128): GC_CONCURRENT freed 698K, 47% free 4162K/7751K, external 1639K/1975K, paused 12ms+12ms

I/Process ( 2371): Sending signal. PID: 2371 SIG: 9

I/ActivityManager( 1128): Process com.android.settings (pid 2371) has died.

 

其中解决问题的关键在于

E/AndroidRuntime( 2371): android.content.ActivityNotFoundException: Unable to find explicit activity class {com.rockchip.ethernetsettings/com.rockchip.ethernetsettings.EthernetSettings}; have you declared this activity in your AndroidManifest.xml?

这个信息。寻找项目对应的AndroidManifest.xml,这个文件存在且正确。而且com.rockchip.ethernetsettings.EthernetSettings这个类的代码也在。

这个错误信息可以理解为,android编译之后会将所有的AndroidManifest.xml组成一个表,在点击相应item的时候触发响应的过程是通过item的name去这个表中找相应的类名,找到类名后,就调用这个类。而以上出错信息提示未找到这个类。怀疑这个类是否真的被编译进镜像了。查看android.mk文件,

ifeq ($(strip $(USE_ETHERNET)),true)

LOCAL_PATH:= $(call my-dir)

include $(CLEAR_VARS)

LOCAL_MODULE_TAGS := eng

LOCAL_SRC_FILES := $(call all-subdir-java-files)

LOCAL_PACKAGE_NAME := EthernetSettings

LOCAL_CERTIFICATE := platform

include $(BUILD_PACKAGE)

endif

发现第一行的宏并没有被定义,在适当的地方添加即可。这里在device/seuic/tiger_mb/device.mk中添加如下:

# Ethernet +++

USE_ETHERNET := true

# Ethernet ---

重新编译,问题解决。

你可能感兴趣的:(转帖)