我正在尝试将我的自定义 View 添加到操作栏中。
final View addView=getLayoutInflater().inflate(R.layout.home_actionbar_buttons, null);
getActionBar().setCustomView(addView);
我的 XML,
<LinearLayout android:id="@+id/linearLayout1"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_height="wrap_content" android:layout_width="match_parent">
<Button android:text="Refresh" android:layout_height="wrap_content"
android:id="@+id/btn_refresh" android:layout_width="wrap_content"></Button>
</LinearLayout
但是我得到空指针异常。当我调试时,addView 对象被填充并且它不为空。 ViewGroupRoot 在膨胀时是强制性的吗?
编辑 1: 日志
09-30 12:50:11.625: DEBUG/PackageManager(74): Activities: com.example.actionbar.MainActivity
09-30 12:50:11.645: INFO/ActivityManager(74): Force stopping package com.example.actionbar uid=10047
09-30 12:50:11.825: INFO/installd(34): move /data/dalvik-cache/data@app@com.example.actionbar-1.apk@classes.dex -> /data/dalvik-cache/data@app@com.example.actionbar-1.apk@classes.dex
09-30 12:50:11.825: DEBUG/PackageManager(74): New package installed in /data/app/com.example.actionbar-1.apk
09-30 12:50:12.215: DEBUG/PackageManager(74): generateServicesMap(android.accounts.AccountAuthenticator): 3 services unchanged
09-30 12:50:12.306: DEBUG/PackageManager(74): generateServicesMap(android.content.SyncAdapter): 5 services unchanged
09-30 12:50:12.475: WARN/RecognitionManagerService(74): no available voice recognition services found
09-30 12:50:12.605: DEBUG/dalvikvm(143): GC_EXPLICIT freed 2K, 17% free 14616K/17415K, paused 5ms+26ms
09-30 12:50:12.985: INFO/AccountTypeManager(202): Loaded meta-data for 1 account types, 0 accounts in 14ms
09-30 12:50:13.555: DEBUG/dalvikvm(143): GC_FOR_ALLOC freed 1125K, 17% free 14564K/17415K, paused 121ms
09-30 12:50:14.435: DEBUG/dalvikvm(143): GC_FOR_ALLOC freed 4109K, 33% free 11749K/17415K, paused 155ms
09-30 12:50:15.254: DEBUG/dalvikvm(143): GC_CONCURRENT freed 1055K, 29% free 12509K/17415K, paused 5ms+10ms
09-30 12:50:15.894: DEBUG/dalvikvm(143): GC_CONCURRENT freed 1109K, 24% free 13406K/17415K, paused 6ms+6ms
09-30 12:50:16.404: DEBUG/dalvikvm(143): GC_CONCURRENT freed 1084K, 18% free 14348K/17415K, paused 5ms+6ms
09-30 12:50:16.924: DEBUG/dalvikvm(74): GC_EXPLICIT freed 752K, 47% free 14474K/26951K, paused 49ms+21ms
09-30 12:50:16.944: DEBUG/AndroidRuntime(1196): Shutting down VM
09-30 12:50:16.994: INFO/AndroidRuntime(1196): NOTE: attach of thread 'Binder Thread #3' failed
09-30 12:50:17.044: DEBUG/dalvikvm(1196): GC_CONCURRENT freed 111K, 84% free 331K/2048K, paused 4ms+1ms
09-30 12:50:17.044: DEBUG/jdwp(1196): Got wake-up signal, bailing out of select
09-30 12:50:17.044: DEBUG/dalvikvm(1196): Debugger has detached; object registry had 1 entries
09-30 12:50:17.974: DEBUG/AndroidRuntime(1210): >>>>>> AndroidRuntime START com.android.internal.os.RuntimeInit <<<<<<
09-30 12:50:17.974: DEBUG/AndroidRuntime(1210): CheckJNI is ON
09-30 12:50:19.174: DEBUG/AndroidRuntime(1210): Calling main entry com.android.commands.am.Am
09-30 12:50:19.234: INFO/ActivityManager(74): Starting: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] flg=0x10000000 cmp=com.example.actionbar/.MainActivity } from pid 1210
09-30 12:50:19.264: WARN/WindowManager(74): Failure taking screenshot for (216x135) to layer 21005
09-30 12:50:19.315: DEBUG/AndroidRuntime(1210): Shutting down VM
09-30 12:50:19.384: INFO/AndroidRuntime(1210): NOTE: attach of thread 'Binder Thread #3' failed
09-30 12:50:19.384: INFO/ActivityManager(74): Start proc com.example.actionbar for activity com.example.actionbar/.MainActivity: pid=1218 uid=10047 gids={}
09-30 12:50:19.484: DEBUG/dalvikvm(1210): GC_CONCURRENT freed 112K, 83% free 358K/2048K, paused 1ms+1ms
09-30 12:50:19.484: DEBUG/jdwp(1210): Got wake-up signal, bailing out of select
09-30 12:50:19.484: DEBUG/dalvikvm(1210): Debugger has detached; object registry had 1 entries
09-30 12:50:22.095: DEBUG/AndroidRuntime(1218): Shutting down VM
09-30 12:50:22.095: WARN/dalvikvm(1218): threadid=1: thread exiting with uncaught exception (group=0x40014760)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): FATAL EXCEPTION: main
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.actionbar/com.example.actionbar.MainActivity}: java.lang.NullPointerException
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1736)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1752)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at android.app.ActivityThread.access$1500(ActivityThread.java:123)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:993)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at android.os.Handler.dispatchMessage(Handler.java:99)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at android.os.Looper.loop(Looper.java:126)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at android.app.ActivityThread.main(ActivityThread.java:3997)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at java.lang.reflect.Method.invokeNative(Native Method)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at java.lang.reflect.Method.invoke(Method.java:491)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at dalvik.system.NativeStart.main(Native Method)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): Caused by: java.lang.NullPointerException
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at com.example.actionbar.MainActivity.onCreate(MainActivity.java:16)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1048)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1700)
09-30 12:50:22.134: ERROR/AndroidRuntime(1218): ... 11 more
09-30 12:50:24.615: DEBUG/dalvikvm(406): GC_EXPLICIT freed 8K, 6% free 6199K/6531K, paused 4ms+382ms
09-30 12:50:26.825: DEBUG/dalvikvm(143): GC_EXPLICIT freed 991K, 16% free 14644K/17415K, paused 977ms+245ms
09-30 12:50:28.545: WARN/ActivityManager(74): Force finishing activity com.example.actionbar/.MainActivity
09-30 12:50:28.545: WARN/WindowManager(74): Failure taking screenshot for (216x135) to layer 21010
09-30 12:50:29.178: WARN/ActivityManager(74): Activity pause timeout for ActivityRecord{40a10fe0 com.example.actionbar/.MainActivity}
09-30 12:50:29.287: WARN/ActivityManager(74): Launch timeout has expired, giving up wake lock!
09-30 12:50:30.925: WARN/ActivityManager(74): Activity idle timeout for ActivityRecord{40a10fe0 com.example.actionbar/.MainActivity}
09-30 12:50:33.144: INFO/Process(1218): Sending signal. PID: 1218 SIG: 9
09-30 12:50:33.344: INFO/ActivityManager(74): Process com.example.actionbar (pid 1218) has died.
09-30 12:50:33.554: WARN/InputManagerService(74): Window already focused, ignoring focus gain of: com.android.internal.view.IInputMethodClient$Stub$Proxy@406a8790
09-30 12:50:33.874: INFO/Process(1179): Sending signal. PID: 1179 SIG: 9
09-30 12:50:36.494: DEBUG/dalvikvm(420): GC_EXPLICIT freed 10K, 6% free 6195K/6531K, paused 7ms+5ms
09-30 12:50:40.959: WARN/ActivityManager(74): Activity destroy timeout for ActivityRecord{40a10fe0 com.example.actionbar/.MainActivity}
09-30 12:50:41.595: DEBUG/dalvikvm(202): GC_EXPLICIT freed 174K, 5% free 6733K/7047K, paused 10ms+4ms
09-30 12:50:46.618: DEBUG/dalvikvm(345): GC_EXPLICIT freed 17K, 5% free 6277K/6599K, paused 7ms+9ms
编辑 2:
添加 setCustomView(R.layout.mylayout.xml); 在添加到 customView 到 actionbar 之前
仍然看不到操作栏中的按钮
最佳答案
我认为您的问题很可能是由于操作栏未包含在您的 Activity 中而导致 getActionBar() 调用失败。尝试添加以下属性:
android:targetSdkVersion="11"
到 list 中的“uses-sdk”节点。通过以蜂窝 SDK 为目标,您将获得一个包含在您的 Activity 中的操作栏。您还可以通过将应用程序的主题设置为 Holo 主题之一来实现此目的。例如
android:theme="@android:style/Theme.Holo.Light"
如果您在 list 的应用程序节点中包含该属性,您还应该获得一个可以使用的操作栏。
您还需要将操作栏上的显示选项设置为 DISPLAY_SHOW_CUSTOM 以显示任何自定义 View 。尝试在设置自定义 View 后添加此行:
getActionBar().setDisplayOptions(ActionBar.DISPLAY_SHOW_CUSTOM);
查看此页面以了解“使用操作栏”下的更多详细信息:http://developer.android.com/reference/android/app/ActionBar.html
希望对您有所帮助!
关于android - 无法将自定义 View 添加到 Android 操作栏,为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7607085/
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
当我使用Bundler时,是否需要在我的Gemfile中将其列为依赖项?毕竟,我的代码中有些地方需要它。例如,当我进行Bundler设置时:require"bundler/setup" 最佳答案 没有。您可以尝试,但首先您必须用鞋带将自己抬离地面。 关于ruby-我需要将Bundler本身添加到Gemfile中吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4758609/
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返