API11(和now12)和Spannable导致运行时NPE

时间:2011-05-11 16:55:44

标签: android

5月14日更新

如果我替换了

,那就是打破它的文本大小的混合
<item name  = "android:textSize">16sp</item> 

只需改变颜色,如

<item name="android:textColor">#00ff00</item>

然后运行正常。

对LogLine的引用,logcat中的度量应该给了我一个线索。 我仍然想修复它,我相信其他人会要求在一个文本行中混合使用大小。

Udpdated 5月12日 - 此帖子末尾显示的最小代码示例

在SDK 2.everything下工作正常的代码,在3.0模拟器中运行时抛出空指针异常。我已经将它缩小到我的代码中唯一出现的SpannableString。我正在使用它将一些不同字体大小的文本放在屏幕顶部的横幅区域中。 logcat是:

FATAL EXCEPTION: main
java.lang.NullPointerException
    at android.text.style.TextAppearanceSpan.updateDrawState(TextAppearanceSpan.java:209)
    at android.text.TextLine.handleRun(TextLine.java:848)
    at android.text.TextLine.measureRun(TextLine.java:399)
    at android.text.TextLine.measure(TextLine.java:278)
    at android.text.TextLine.metrics(TextLine.java:252)
    at android.text.Layout.measurePara(Layout.java:1432)
    at android.text.Layout.getDesiredWidth(Layout.java:89)
    at android.text.Layout.getDesiredWidth(Layout.java:68)
    at android.widget.TextView.onMeasure(TextView.java:5713)
    at android.view.View.measure(View.java:10577)
    at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:581)
    at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:365)
    at android.view.View.measure(View.java:10577)
    at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:581)
    at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:365)
    at android.view.View.measure(View.java:10577)
    at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:581)
    at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:365)
    at android.view.View.measure(View.java:10577)
    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4270)
    at android.widget.FrameLayout.onMeasure(FrameLayout.java:267)
    at android.view.View.measure(View.java:10577)
    at android.widget.LinearLayout.measureVertical(LinearLayout.java:764)
    at android.widget.LinearLayout.onMeasure(LinearLayout.java:519)
    at android.view.View.measure(View.java:10577)
    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4270)
    at android.widget.FrameLayout.onMeasure(FrameLayout.java:267)
    at com.android.internal.policy.impl.PhoneWindow$DecorView.onMeasure(PhoneWindow.java:1876)
    at android.view.View.measure(View.java:10577)
    at android.view.ViewRoot.performTraversals(ViewRoot.java:885)
    at android.view.ViewRoot.handleMessage(ViewRoot.java:1944)
    at android.os.Handler.dispatchMessage(Handler.java:99)
    at android.os.Looper.loop(Looper.java:126)
    at android.app.ActivityThread.main(ActivityThread.java:3997)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:491)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
    at dalvik.system.NativeStart.main(Native Method)

代码位于由计时器调用的处理程序中,它使用以下基本行写入文本视图(省略空检查等)

TextView tvBanner = (TextView) findViewById(R.id.RefText);
.....
int startSpan = altDispStr.indexOf("\n");
int endSpan = altDispStr.length();
spanRange = new SpannableString(altDispStr);
spanRange.setSpan(new TextAppearanceSpan(this,
    R.style.custompoint), startSpan, endSpan,
    Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);

....
....
tvBanner.setText(spanRange);

当我在调试器中捕获它时(使用3.0模拟器和3GB内存不容易)它通过处理程序方法OK, - spanRange不为null,但NPE和FC稍后会在主循环中发生。< / p>

textview(RefTxt)位于一个名为infobar.xml的xml中,该文件包含在main.xml中。信息栏的基本组成部分是:

<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/BannerRelView"
android:layout_alignParentTop="true"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:background="#800000ff"
android:layout_width="wrap_content">
    <TextView
       android:id="@+id/BannerOptionsButton"      
       android:layout_alignParentRight="true"   
       ....     
     </TextView>
     <TextView
         android:id="@+id/BannerGPS"
         android:layout_toLeftOf="@+id/BannerOptionsButton"    
         ....
      </TextView>
      <TextView
         android:id="@+id/RefText"
         android:layout_toLeftOf="@+id/BannerGPS"
         ......
      </TextView>
</RelativeLayout>

如果我用普通的旧String替换SpannableString,那么该应用程序将在3.0模拟器中运行。 我想知道我是否需要使用Spannables和平板电脑设备采取额外的措施?

当它死亡时,调试透视图显示 crash state - mt和tl都不为空

更新示例 我把它减少到最小的代码示例,它演示了错误,它在2.1下可以正常但在3.0以下的相同NPE崩溃

活动代码:

public class SpanTest extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        String dispStr = "I'm the first line\nI'm the second line";
        TextView tvBanner = (TextView) findViewById(R.id.textView1);
        int startSpan = dispStr.indexOf("\n");
        int endSpan = dispStr.length();
        Spannable spanRange = new SpannableString(dispStr);
        spanRange.setSpan(new TextAppearanceSpan(this, R.style.custompoint), startSpan, endSpan, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
        tvBanner.setText(spanRange);
    }
}

main.xml是一个只包含一个TextView的LinearLayout。我的包含custompoint的styles.xml是:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <style
        name="custompoint">
        <item name="android:textSize">24sp</item>
        <item name="android:textStyle">bold</item>
    </style>
</resources>

1 个答案:

答案 0 :(得分:7)

您的TextView正在使用未设置linkColor的TextPaint对象。我看到你使用的样式/主题不知何故没有设置linkColor。尝试在样式中添加linkColor,看看是否能解决问题。

编辑:您应该继承默认样式,这样可以提供您想要的内容。不确定为什么行为从2.1变为3.0,但是......