- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试构建 Settings.apk 以在 Google I/O 的 Hacking Glass session 上用于 Glass:https://www.youtube.com/watch?feature=player_detailpage&v=OPethpwuYEk#t=500s
他提到为了让设置 apk 工作,需要修改 list 中的一行。这是 AOSP list :
http://pastebin.com/2yQ3QEgX (由于篇幅已添加到pastebin)
每次我运行设置应用程序时,它都会崩溃,这是 logcat 输出:
I/PowerManagerService( 184): Auto-brightness: light sensor = 320, brightness = 255
D/Watchdog( 683): Checking for errors
D/dalvikvm( 683): GC_CONCURRENT freed 363K, 43% free 9944K/17223K, paused 3ms+2ms
D/dalvikvm( 683): GC_CONCURRENT freed 382K, 42% free 10074K/17223K, paused 3ms+1ms
D/dalvikvm( 683): GC_CONCURRENT freed 363K, 41% free 10191K/17223K, paused 2ms+2ms
D/dalvikvm( 683): GC_CONCURRENT freed 529K, 42% free 10147K/17223K, paused 4ms+2ms
I/ActivityManager( 184): START {act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] flg=0x10200000 cm
p=com.android.settings/.Settings} from pid 4506
D/dalvikvm( 683): GC_CONCURRENT freed 323K, 41% free 10244K/17223K, paused 2ms+2ms
D/dalvikvm( 683): GC_FOR_ALLOC freed 229K, 41% free 10314K/17223K, paused 60ms
I/ActivityManager( 184): Start proc com.android.settings for activity com.android.settings/.Settings: pid=4998 uid=1003
0 gids={1015, 3002, 3001, 3003}
D/OpenGLRenderer( 471): Flushing caches (mode 1)
D/OpenGLRenderer( 4506): Flushing caches (mode 1)
D/OpenGLRenderer( 4506): Flushing caches (mode 0)
W/System.err( 4998): Removed 2131231170
W/System.err( 4998): Removed 2131231177
W/InputManagerService( 184): Starting input on non-focused client com.android.internal.view.IInputMethodClient$Stub$Pro
xy@418cfb28 (uid=10029 pid=4506)
D/dalvikvm( 683): GC_CONCURRENT freed 342K, 40% free 10419K/17223K, paused 63ms+3ms
D/LocalBluetoothProfileManager( 4998): LocalBluetoothProfileManager construction complete
D/dalvikvm( 4998): GC_CONCURRENT freed 136K, 3% free 9364K/9607K, paused 2ms+2ms
D/dalvikvm( 683): GC_FOR_ALLOC freed 354K, 39% free 10576K/17223K, paused 23ms
D/libEGL ( 4998): loaded /system/lib/egl/libGLES_android.so
D/libEGL ( 4998): loaded /vendor/lib/egl/libEGL_POWERVR_SGX540_120.so
D/libEGL ( 4998): loaded /vendor/lib/egl/libGLESv1_CM_POWERVR_SGX540_120.so
D/libEGL ( 4998): loaded /vendor/lib/egl/libGLESv2_POWERVR_SGX540_120.so
D/dalvikvm( 683): GC_CONCURRENT freed 121K, 39% free 10615K/17223K, paused 2ms+4ms
D/dalvikvm( 683): GC_FOR_ALLOC freed 38K, 39% free 10576K/17223K, paused 37ms
I/dalvikvm-heap( 683): Grow heap (frag case) to 11.089MB for 725488-byte allocation
D/OpenGLRenderer( 4998): Enabling debug mode 0
D/BluetoothAdapterStateMachine( 184): BluetoothOn process message: 1
W/BluetoothAdapterStateMachine( 184): BluetoothOn received: 1
D/AndroidRuntime( 4998): Shutting down VM
W/dalvikvm( 4998): threadid=1: thread exiting with uncaught exception (group=0x40d821f8)
D/dalvikvm( 683): GC_FOR_ALLOC freed 472K, 38% free 10812K/17223K, paused 51ms
E/AndroidRuntime( 4998): FATAL EXCEPTION: main
E/AndroidRuntime( 4998): java.lang.NullPointerException
E/AndroidRuntime( 4998): at com.android.settings.Settings$HeaderAdapter.getView(Settings.java:515)
E/AndroidRuntime( 4998): at android.widget.AbsListView.obtainView(AbsListView.java:2033)
E/AndroidRuntime( 4998): at android.widget.ListView.makeAndAddView(ListView.java:1772)
E/AndroidRuntime( 4998): at android.widget.ListView.fillDown(ListView.java:672)
E/AndroidRuntime( 4998): at android.widget.ListView.fillFromTop(ListView.java:732)
E/AndroidRuntime( 4998): at android.widget.ListView.layoutChildren(ListView.java:1625)
E/AndroidRuntime( 4998): at android.widget.AbsListView.onLayout(AbsListView.java:1863)
E/AndroidRuntime( 4998): at android.view.View.layout(View.java:11279)
E/AndroidRuntime( 4998): at android.view.ViewGroup.layout(ViewGroup.java:4224)
E/AndroidRuntime( 4998): at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1628)
E/AndroidRuntime( 4998): at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1486)
E/AndroidRuntime( 4998): at android.widget.LinearLayout.onLayout(LinearLayout.java:1399)
E/AndroidRuntime( 4998): at android.view.View.layout(View.java:11279)
E/AndroidRuntime( 4998): at android.view.ViewGroup.layout(ViewGroup.java:4224)
E/AndroidRuntime( 4998): at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1628)
E/AndroidRuntime( 4998): at android.widget.LinearLayout.layoutHorizontal(LinearLayout.java:1617)
E/AndroidRuntime( 4998): at android.widget.LinearLayout.onLayout(LinearLayout.java:1401)
E/AndroidRuntime( 4998): at android.view.View.layout(View.java:11279)
E/AndroidRuntime( 4998): at android.view.ViewGroup.layout(ViewGroup.java:4224)
E/AndroidRuntime( 4998): at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1628)
E/AndroidRuntime( 4998): at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1486)
E/AndroidRuntime( 4998): at android.widget.LinearLayout.onLayout(LinearLayout.java:1399)
E/AndroidRuntime( 4998): at android.view.View.layout(View.java:11279)
E/AndroidRuntime( 4998): at android.view.ViewGroup.layout(ViewGroup.java:4224)
E/AndroidRuntime( 4998): at android.widget.FrameLayout.onLayout(FrameLayout.java:431)
E/AndroidRuntime( 4998): at android.view.View.layout(View.java:11279)
E/AndroidRuntime( 4998): at android.view.ViewGroup.layout(ViewGroup.java:4224)
E/AndroidRuntime( 4998): at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1628)
E/AndroidRuntime( 4998): at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1486)
E/AndroidRuntime( 4998): at android.widget.LinearLayout.onLayout(LinearLayout.java:1399)
E/AndroidRuntime( 4998): at android.view.View.layout(View.java:11279)
E/AndroidRuntime( 4998): at android.view.ViewGroup.layout(ViewGroup.java:4224)
E/AndroidRuntime( 4998): at android.widget.FrameLayout.onLayout(FrameLayout.java:431)
E/AndroidRuntime( 4998): at android.view.View.layout(View.java:11279)
E/AndroidRuntime( 4998): at android.view.ViewGroup.layout(ViewGroup.java:4224)
E/AndroidRuntime( 4998): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1498)
E/AndroidRuntime( 4998): at android.view.ViewRootImpl.handleMessage(ViewRootImpl.java:2451)
E/AndroidRuntime( 4998): at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime( 4998): at android.os.Looper.loop(Looper.java:137)
E/AndroidRuntime( 4998): at android.app.ActivityThread.main(ActivityThread.java:4424)
E/AndroidRuntime( 4998): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime( 4998): at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime( 4998): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
E/AndroidRuntime( 4998): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
E/AndroidRuntime( 4998): at dalvik.system.NativeStart.main(Native Method)
W/ActivityManager( 184): Force finishing activity com.android.settings/.Settings
W/ActivityManager( 184): Force finishing activity com.android.launcher/com.android.launcher2.Launcher
D/dalvikvm( 683): GC_FOR_ALLOC freed 317K, 38% free 10812K/17223K, paused 35ms
I/dalvikvm-heap( 683): Grow heap (frag case) to 11.666MB for 1088228-byte allocation
D/dalvikvm( 683): GC_CONCURRENT freed 0K, 32% free 11875K/17223K, paused 3ms+3ms
D/dalvikvm( 683): GC_FOR_ALLOC freed 1185K, 36% free 11167K/17223K, paused 29ms
I/dalvikvm-heap( 683): Grow heap (frag case) to 12.530MB for 1632338-byte allocation
D/dalvikvm( 683): GC_CONCURRENT freed 1062K, 33% free 11698K/17223K, paused 2ms+2ms
D/dalvikvm( 683): GC_FOR_ALLOC freed 179K, 33% free 11698K/17223K, paused 23ms
I/dalvikvm-heap( 683): Grow heap (frag case) to 12.666MB for 1229980-byte allocation
D/dalvikvm( 683): GC_CONCURRENT freed 0K, 26% free 12899K/17223K, paused 2ms+2ms
W/ActivityManager( 184): Activity pause timeout for ActivityRecord{416eb7f8 com.android.settings/.Settings}
V/MainTimelineActivity( 471): onStart: 416dc890
D/MainTimelineActivity( 471): Already in guest mode state: false
V/MainTimelineActivity( 471): onResume: 416dc890
D/InputDetector( 471): Binding voice service
D/SafeBroadcastReceiver( 471): Registered receiver 'MainTimelineActivity/longPressInterceptor'.
D/BaseHorizontalScrollView( 471): Activating.
D/ActiveItemAdapter( 471): Activating adapter.
D/OngoingActivityService( 471): Added listener ActiveItemAdapter, count=1
D/SafeBroadcastReceiver( 471): Registered receiver 'SettingsCoverView/stateReceiver'.
W/SafeBroadcastReceiver( 471): Not registering receiver 'InetConnectionState/connectivityReceiver', because it is alrea
dy registered.
D/SafeBroadcastReceiver( 471): Registered receiver 'BluetoothTetheringState/stateChangeReceiver'.
V/BatteryHelper( 471): Current battery percent: 94.0
I/BatteryHelper( 471): Driver is not reporting charged, checking percent.
V/BatteryHelper( 471): Current battery percent: 94.0
V/BatteryHelper( 471): Battery is charged? false
V/BatteryHelper( 471): Battery currently charging? true
V/BatteryHelper( 471): Battery currently charging? true
I/BatteryHelper( 471): Driver is not reporting charged, checking percent.
V/BatteryHelper( 471): Current battery percent: 94.0
V/BatteryHelper( 471): Battery is charged? false
W/InputDetector( 471): Trying to change VoiceConfig before connection to VoiceService established
D/MainTimelineView( 471): Updating cursor select args: [1371680604322]
D/MainTimelineView( 471): Updating cursor select args: [1369088614323]
D/MainTimelineActivity( 471): There is no pending task, checking for pending runnable.
D/MainTimelineActivity( 471): No pending intent, showing the timeline.
W/MainTimelineActivity( 471): No wake up time known.
D/MainTimelineActivity( 471): Setting isFromScreenOffNotification: false
D/InputDetector( 471): Voice service connected
V/BatteryHelper( 471): Current battery percent: 94.0
I/BatteryHelper( 471): Driver is not reporting charged, checking percent.
V/BatteryHelper( 471): Current battery percent: 94.0
V/BatteryHelper( 471): Battery is charged? false
V/BatteryHelper( 471): Battery currently charging? true
V/BatteryHelper( 471): Battery currently charging? true
I/BatteryHelper( 471): Driver is not reporting charged, checking percent.
V/BatteryHelper( 471): Current battery percent: 94.0
V/BatteryHelper( 471): Battery is charged? false
D/UserEventHelper( 471): Logging user event [action=UI_THREAD_QUEUE, data=|a=11.000|v=98.000|].
D/UserEventHelper( 471): Logging user event [action=UI_TIME_TO_RENDER, data=|a=0.707|v=0.962|].
D/UserEventHelper( 471): Logging user event [action=UI_TIME_BETWEEN_RENDERS, data=|a=20.974|v=164.447|].
D/MainTimelineActivity( 471): Voice Service Connected
D/MainTimelineActivity( 471): getting config from timelineView
D/VoiceService( 471): setConfig called with VoiceConfig:OFF
D/TimelineCursorManager( 471): Received updated cursor: 160
D/MainTimelineView( 471): New timeline database content loaded; updating views.
D/TimelineCursorManager( 471): Received updated cursor: 160
D/MainTimelineView( 471): New timeline database content loaded; updating views.
V/BatteryHelper( 471): Current battery percent: 94.0
I/BatteryHelper( 471): Driver is not reporting charged, checking percent.
V/BatteryHelper( 471): Current battery percent: 94.0
V/BatteryHelper( 471): Battery is charged? false
V/BatteryHelper( 471): Battery currently charging? true
V/BatteryHelper( 471): Battery currently charging? true
I/BatteryHelper( 471): Driver is not reporting charged, checking percent.
V/BatteryHelper( 471): Current battery percent: 94.0
V/BatteryHelper( 471): Battery is charged? false
D/dalvikvm( 471): GC_CONCURRENT freed 2947K, 21% free 27249K/34183K, paused 4ms+23ms
V/BatteryHelper( 683): Battery currently charging? true
I/BatteryHelper( 683): Driver is not reporting charged, checking percent.
V/BatteryHelper( 683): Current battery percent: 94.0
V/BatteryHelper( 683): Battery is charged? false
V/BatteryHelper( 683): Battery currently charging? true
I/BatteryHelper( 683): Driver is not reporting charged, checking percent.
V/BatteryHelper( 683): Current battery percent: 94.0
V/BatteryHelper( 683): Battery is charged? false
V/BatteryHelper( 683): Battery currently charging? true
I/BatteryHelper( 683): Driver is not reporting charged, checking percent.
V/BatteryHelper( 683): Current battery percent: 94.0
V/BatteryHelper( 683): Battery is charged? false
I/PowerManagerService( 184): Auto-brightness: light sensor = 239, brightness = 255
对于 list 中应该修改哪些内容才能使其正常工作,有什么想法吗?
最佳答案
对于来自 ICS MR1 分支的设置 apk,除了删除 AndroidManifest 中的 sharedUserId 字段...
您看到的崩溃是因为 holder 的图标和摘要字段为空。com.android.internal.R.layout.preference_header_item 是一个简单的 TextView。
如果你换入 R.layout.preference_header_switch_item,并隐藏开关,它应该可以工作。
@@ -480,9 +481,10 @@ public class Settings extends PreferenceActivity implements ButtonBarHandler {
case HEADER_TYPE_NORMAL:
view = mInflater.inflate(
- com.android.internal.R.layout.preference_header_item, parent,
+ R.layout.preference_header_switch_item, parent,
false);
- holder.icon = (ImageView) view.findViewById(com.android.internal.R.id.icon);
+ view.findViewById(R.id.switchWidget).setVisibility(View.GONE);
+ holder.icon = (ImageView) view.findViewById(R.id.icon);
holder.title = (TextView)
view.findViewById(com.android.internal.R.id.title);
holder.summary = (TextView)
关于java - 修改 Settings.apk 以使用 Project Glass,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16659552/
我有一组称为 nets 的整数集,我正在尝试对其进行迭代以确定是否已将来自或来自的整数添加到现有集合中;如果是这样,我将它们添加到现有集合中(这是为了跟踪电网中所有短路的组合)。 但是,我无法让 se
很奇怪:A 是一个集合,B 是一个集合的集合: Set A=new HashSet(); Set > B=new HashSet>(); 我给他们加了东西,输出 System.out.println
在 Agda 中,forall 的类型以这样的方式确定以下所有类型都是Set1 (其中 Set1 是 Set 的类型, A 的类型是 Set ): Set → A A → Set Set → Set
在 haskell 中我可以写一个函数 f where f :: Set a -> Set a -> Set a 如果我采用 Set Int 类型的两组 s1 和 s2,然后执行 f s1 s2 它将
在使用 Spring 时,我遇到了一个奇怪的问题。我有一个类,它接受一个集合作为输入,因为该类是底层框架的,所以我无法更改它。这是它的声明 private Set evaluate; public S
我是流的新手,我想通过将流操作应用于其条目集来修改 map ,但由于编译错误我无法这样做。 下面的代码只是创建了一个新的 map 对象并为其分配了一些整数值。然后它尝试通过在其条目集上应用流操作来删除
无论我看什么,我都会看到集合的输入是这样完成的: Set set = new HashSet(); 但是,我像这样定义我的集合 Set set = new HashSet(); 而且我仍然进行类型检查
我想对于 set -e 我可以捕获信号,但其他的我不知道。 最佳答案 为了完整性: set -e:如果命令失败则退出 set -u:如果在设置之前引用变量,则会出现错误 set -x:显示运行的命令
Set 维护唯一记录,并在尝试复制现有元素时更新现有记录。 考虑以下两种情况。您认为两者之间哪一个代码更快、更高效? 场景 1:使用 addAll() Set uniqueSet = new Hash
我在 Fedora 上做这个 问题: (sandbox)[root@localhost mysite]# django-admin.py runserver Error: Could not impo
https://codeforces.com/contest/1435/submission/96757666->使用set.upper_bound() https://codeforces.com/
使用 MySQL,我已将连接字符集设置为 UTF-8: SET NAMES 'utf8mb4'; SET CHARACTER SET 'utf8mb4'; 这样我就能以 UTF-8 格式返回所有内容,
在 Spring 3 MVC 中,我有一个称为 SettingsController 的 Controller ,它具有用于显示用户列表的 displayUsers()、saveUser() 和 de
我正在创建一个使用语法的程序,并查看该语法是否为 LL (1)。我想使用模块Set,但是我不知道如何进行,当然set的元素的类型是char,你能帮忙吗? 最佳答案 此答案假设您已经知道如何确定语法是否
好的,所以我重新整理了这篇文章,使其更容易理解(对所有的 Pastebin 感到抱歉,但堆栈溢出在代码格式化方面很愚蠢) 请注意,我不打算存储如下所述的大量数据。我使用我所说的数量的主要原因是为了尽可
我有一个密码,我保存在 Settings.settings 文件中并且我希望该部分被加密。 This是我得到的提示,但我真的不知道如何应用它。 谁能给我一个关于如何加密这样的密码的想法? 最佳答案 您
我在网上搜索并找到了如何在设置中添加特定的自定义数据类型。 我自己插入数据,而不是在程序运行时通过代码插入数据。我的问题是如何将自定义数据类型添加到设计器中的组合框。现在我想通了,需要建议,如何添加这
我一直在尝试将自定义类的自定义集合添加到我的 winforms 项目的应用程序设置中,我觉得我已经尝试了六种不同的方法,包括 this way , this way , this way , 和 th
在 Visual Studio 2008 中调试我的项目时,我的 Settings.settings 文件在构建之间不断重置。有没有办法防止这种情况发生? 谢谢。 最佳答案 好的,我找到了我真正想要的
关闭。这个问题不符合 Stack Overflow guidelines 。它目前不接受答案。 想改善这个问题吗?更新问题,以便堆栈溢出为 on-topic。 4年前关闭。 Improve this
我是一名优秀的程序员,十分优秀!