修改 Settings.apk 以与 Project Glass 配合使用

2024-05-08

我正在尝试构建要在 Google I/O 的 Hacking Glass 会议上在 Glass 上使用的 Settings.apk:

他提到,为了让设置 apk 正常工作,需要修改清单中的一行。这是 AOSP 清单:

http://pastebin.com/2yQ3QEgX 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

为了使其正常工作,您有什么想法应该修改清单中的内容吗?


对于来自 ICS MR1 分支的设置 apk,除了删除 AndroidManifest 中的sharedUserId 字段之外...

您看到的崩溃是因为持有者的图标和摘要字段为空。 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)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

修改 Settings.apk 以与 Project Glass 配合使用 的相关文章

随机推荐

  • ASP.NET Core API:身份验证弹出窗口未显示在 Swagger UI 中

    我有一个 ASP NET Core Web API 其中使用 Swashbuckle 集成了 Swagger 我已经使用操作过滤器成功在 Swagger UI 上集成了授权 因为我不想显示匿名 API 的挂锁 OperationFilter
  • Jupyter (iPython) 笔记本中的 Latex 宏未由 github 渲染

    我的 Jupyter 笔记本 ipynb 中有一个 Markdown 单元 其中包含以下内容 newcommand paren 1 left 1 right paren beta 2 该文件位于 Github 存储库中 LaTex 宏应用程
  • 如何将自定义迁移添加到外部 Django 应用程序

    我已经在我的自定义 Django 1 10 应用程序中对一些第三方应用程序进行了一些猴子修补 现在 当我尝试创建初始迁移时 它还会为这些外部应用程序生成迁移 但它将这些迁移放在我的 virtualenv 的站点中 packages 目录 无
  • 如何迭代 RecyclerView 项目

    在我的应用程序中 我有一个带有简单项目视图的 RecyclerView 该视图由每行中的 TextView 和 Spinner 组成 用户从操作栏中单击 保存 后 我需要迭代所有项目并获取 Spinner 选择的值 有什么想法可以或应该如何
  • nix 用户包与系统包

    I use Vagrant virtualBox and a Debian 8 Ubuntu我的开发环境的图像 我想用nix https nixos org nix用于配置 但我无法获取nixOS完全正确地工作 即网络 配置 但我非常乐意切
  • 如何创建无法创建新文档的基于文档的应用程序?

    我有一个基于文档的应用程序 旨在处理现有文档 而不是创建新文档 如何防止应用程序在通过 Finder 打开应用程序时创建新的空白文档 您可以实现一个 NSApplication 委托协议方法 BOOL applicationShouldOp
  • 如何使用 Python Argparse 制作所需参数的短版本和长版本?

    我想指定一个名为的必需参数inputdir但我也想要它的简写版本i 我没有看到一个简洁的解决方案来做到这一点 而不使用两个可选参数 然后进行我自己的检查 是否有我没有看到的首选做法 或者唯一的方法是将两者设为可选并进行我自己的错误处理 这是
  • 确定范围是否重叠

    给定两个具有整数开始时间和结束时间的事件 E1 s1 e1 E2 s2 e2 实现快速布尔检查以查看事件是否重叠 我有解决方案 但我很想看看其他人想出了什么 编辑 好的 这是我的解决方案 e1 gt s2 s1 gt s2 e2 lt s1
  • 在开发模式下安装包(R源未编译成Rdb)

    我需要修改R代码在一个R具有 Fortran 绑定的包 当我安装软件包时 我看到存储库目录没有源代码 但是 Rdb而是二进制文件 我看了看devtools包 但我仍然不清楚如何在不编译 R 源部分的情况下安装该包 类似于 python py
  • NPM ci 之后的 NPM 修剪

    我有一个天真的问题 在 npm ci 之后进行 npm prune 是否有兴趣 对我来说 npm ci 似乎就足够了 不是吗 提前致谢 由于 npm ci 在安装之前删除了现有的 node modules 因此无需修剪 Npm prune
  • UIModalPresentationFormSheet 的圆角

    如果这是一个明显的问题 请原谅我 我是个相对较新的人 我有一个模态视图 我设置了自定义尺寸和圆角 void viewWillLayoutSubviews super viewWillLayoutSubviews self view supe
  • 如何使用一个凉亭同时创建两个地图?

    如下图所示 现在我的gazebo正在运行2个slam gmapping包 首先是 turtlebot slam gmapping 发布到 map 主题 第二个是 slam gmapping 发布到与第一个相同的 map 主题 我想创建一个新
  • 在操作栏中编辑文本

    我正在使用 Action Bar Sherlock 为我的应用程序创建 UI 在将依赖项添加到我的项目等后 我创建了一个活动来测试它 public class PPS extends SherlockActivity Override pu
  • 在用例建模中分解 CRUD

    我有一个后续问题用例图中的 CRUD https stackoverflow com questions 7772399 crud in a use case diagram 如果我需要分解复杂的用例 例如 管理用户 假设这很复杂 可以将它
  • 管道序列中的异常处理

    我正在开发一个基本的 2D CAD 引擎 管道操作符显着改进了我的代码 基本上 有几个函数从空间中的点 x y 开始 并在多次移动操作后计算最终位置 let finalPosition startingPosition gt moveByL
  • SeekBar setProgress 丢弃次要进度

    我的小学和中学的进步是同时增长的 中学的进步比小学的进步快 每次我更新主要进度时 次要进度都会丢失 就像它为零或小于主要进度一样 这会产生令人讨厌的闪烁 我发现的唯一解决方法是在设置主数据库后将辅助数据库设置为自身 我添加了 1 因为 Se
  • 如何使用延迟位置 iOS 6?

    我正在尝试使用新的 iOS 6 延迟位置更新功能 但不断收到此错误 didFinishDeferredUpdatesWithError Error Domain kCLErrorDomain Code 11 操作无法完成 kCLErrorD
  • 检查数独字段的很酷的算法?

    有谁知道一个简单的算法来检查数独配置是否有效 我想出的最简单的算法是 对于大小为 n 的板 伪代码 for each row for each number k in 1 n if k is not in the row using ano
  • 奇异矩阵 - python

    下面的代码显示了矩阵的奇异性问题 因为在 Pycharm 中工作我得到 raise LinAlgError Singular matrix numpy linalg linalg LinAlgError Singular matrix 我猜
  • 修改 Settings.apk 以与 Project Glass 配合使用

    我正在尝试构建要在 Google I O 的 Hacking Glass 会议上在 Glass 上使用的 Settings apk 他提到 为了让设置 apk 正常工作 需要修改清单中的一行 这是 AOSP 清单 http pastebin