Android TextView setText 覆盖之前的Text

Posted

技术标签:

【中文标题】Android TextView setText 覆盖之前的Text【英文标题】:Android TextView setText overlays previous Text 【发布时间】:2013-05-06 01:38:04 【问题描述】:

我想在我的应用程序(lication)的 TextView 中设置一个 Text。这是我使用的代码:

TextView lonTextView = (TextView) findViewById(R.id.textViewLonWert);
lonTextView.setText(longitude.toString());

其实是可以的,但是还是显示了之前的Text!例如 4 覆盖 8 (您无法再阅读文本)。

我有一个启动服务的活动。然后将 LocalBroadcastReceiver 注册到 Activity。该服务定期将位置对象发送到活动。从我得到的位置,例如经度,并想用新的经度更新一个文本视图(只包含经度)。

如果有人有解决此问题的想法,我将非常高兴。

更新: 完整代码比较长,下面是相关片段:

TrackingActivity.java

public class TrackingActivity extends Activity 

// GPSTracker class
GPSTracker gps; 

public String filename;

/* Um eigene Position anzuzeigen */
ArrayList<OverlayItem> overlayItemArray;
protected MapView mapView;
protected MapController mapController;
public Boolean isPause;
public Boolean isTracking;
public MyLocationOverlay myLocationOverlay;
PathOverlay myPath;
List<GeoPoint> path;

public BroadcastReceiver screenReceiver;

/* Textviews setzen */
TextView lonTextView;
TextView latTextView;
TextView altTextView;
TextView accTextView;

// Initiating Menu XML file (menu.xml)
/*@Override
public boolean onCreateOptionsMenu(Menu menu)


    MenuInflater menuInflater = getMenuInflater();
    menuInflater.inflate(R.menu.menu_tracking, menu);
    MenuItem mi_startTracking = menu.findItem(R.id.start_tracking);
    mi_startTracking.setVisible(true);
    return true;
*/

/**
 * Event Handling for Individual menu item selected
 * Identify single menu item by it's id
 * */
@Override
public boolean onOptionsItemSelected(MenuItem item)

    ...
    

@Override

public boolean onPrepareOptionsMenu(Menu menu) 
   ...


@Override
public void onCreate(Bundle savedInstanceState) 
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_tracking);

    isTracking  = false;
    isPause     = false;

    // create GPS-class object
    gps = new GPSTracker(TrackingActivity.this
                        ,null);

    myPath  = new PathOverlay(Color.RED, this);
    path    = new ArrayList<GeoPoint>();

   /* Map anzeigen */
    mapView = new MapView(this, 500);
    mapView.setTileSource(TileSourceFactory.MAPNIK);
    org.osmdroid.views.MapView.LayoutParams mapParams = new                   org.osmdroid.views.MapView.LayoutParams(
            org.osmdroid.views.MapView.LayoutParams.MATCH_PARENT,
            org.osmdroid.views.MapView.LayoutParams.MATCH_PARENT,
            null, 0, 0, 0);
    /*löst Fehler aus: mapView.setClickable(true);*/
    mapView.setBuiltInZoomControls(true);
    mapController = new MapController(mapView);
    mapView.getController().setZoom(15);


    //--- Create Overlay
    overlayItemArray = new ArrayList<OverlayItem>();

    DefaultResourceProxyImpl defaultResourceProxyImpl   = new DefaultResourceProxyImpl(this);
    MyItemizedIconOverlay myItemizedIconOverlay         = new MyItemizedIconOverlay(
                                                        overlayItemArray, null, defaultResourceProxyImpl);
    mapView.getOverlays().add(myItemizedIconOverlay);
    //---

    //Add current position
    myLocationOverlay = new MyLocationOverlay(this, mapView);
    mapView.getOverlays().add(myLocationOverlay);

    /* Lege Pfad auf Karte */
    mapView.getOverlays().add(myPath);
    mapView.invalidate();
    LinearLayout myLayout = (LinearLayout) findViewById(R.id.trackingLinearLayoutMap);

    myLayout.addView(mapView,mapParams);



private BroadcastReceiver gpsDataReceiver = new BroadcastReceiver() 

    @Override
    public void onReceive(Context context, Intent intent) 

        //Log.d("TrackingActivity", "in Receiver");
        /* alles was der Service liefert */
        String action       = intent.getAction();
        Double altitude     = intent.getDoubleExtra("altitude", 0);
        Double longitude    = intent.getDoubleExtra("longitude", 0);
        Double latitude     = intent.getDoubleExtra("latitude", 0);
        Bundle b            = intent.getExtras();
        Location location   = (Location)b.get("location");

        Log.d("received","Receiver: "+longitude+" ; "+latitude);


        //Log.d("TrackingActivity", "vor GeoPoint");
        GeoPoint locGeoPoint = new GeoPoint(latitude, longitude);

                /* Erstelle Pfad */
        if(isTracking)
            path.add(locGeoPoint);
            myPath.addPoint(locGeoPoint);
        
        //Log.d("TrackingActivity", "nach GeoPoint: "+locGeoPoint.toString());
        mapController.setCenter(locGeoPoint);

        setOverlayLoc(location);

        /* Textviews Werte setzen */
        lonTextView = (TextView) findViewById(R.id.textViewLonWert);
        lonTextView.setText(longitude.toString());
        //lonTextView.invalidate();

        latTextView = (TextView) findViewById(R.id.textViewLatWert);
        latTextView.setText(latitude.toString());
        //latTextView.invalidate();

        altTextView = (TextView) findViewById(R.id.textViewAltWert);
        altTextView.setText(altitude.toString());
        //altTextView.invalidate();

        accTextView = (TextView) findViewById(R.id.textViewAccWert);
        accTextView.setText(Float.toString(location.getAccuracy())+" m");
        //accTextView.invalidate();

        /* Karte aktualisieren */
        mapView.invalidate();

    
;
...
@Override
protected void onResume() 
    super.onResume();
    /* Registriere BroadcastReceiver für GPSDaten */
    LocalBroadcastManager.getInstance(this).registerReceiver(gpsDataReceiver, new IntentFilter("gpsdata"));

        ...


...

这是我的布局 .xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/trackingLinearLayout"
android:layout_
android:layout_
android:orientation="vertical" >

<LinearLayout
    android:id="@+id/trackingStatusOuterWrapper"
    android:layout_
    android:layout_
    android:orientation="vertical" >

    <TextView
        android:id="@+id/textView1"
        android:layout_
        android:layout_
        android:text="kein GPS Signal"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textSize="10sp" />

    <LinearLayout
    android:id="@+id/trackingStautsInnerWrapper2"
    android:layout_
    android:layout_
    android:orientation="horizontal" >
        <TextView
        android:id="@+id/textViewLonLabel"
        android:layout_
        android:layout_
        android:text="Länge: "
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textSize="10sp" />
        <TextView
        android:id="@+id/textViewLonWert"
        android:layout_
        android:layout_
        android:text=""
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textSize="10sp" />
        <TextView
        android:id="@+id/textViewLatLabel"
        android:layout_marginLeft="40dp"
        android:layout_
        android:layout_
        android:text="Breite: "
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textSize="10sp" />
        <TextView
        android:id="@+id/textViewLatWert"
        android:layout_
        android:layout_
        android:text=""
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textSize="10sp" />

    </LinearLayout>
    <LinearLayout
    android:id="@+id/trackingStautsInnerWrapper3"
    android:layout_
    android:layout_
    android:orientation="horizontal" >

        <TextView
        android:id="@+id/textViewAltLabel"
        android:layout_
        android:layout_
        android:text="Höhe: "
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textSize="10sp" />
        <TextView
        android:id="@+id/textViewAltWert"
        android:layout_
        android:layout_
        android:text=""
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textSize="10sp" />
        <TextView
        android:id="@+id/textViewAccLabel"
        android:layout_marginLeft="40dp"
        android:layout_
        android:layout_
        android:text="Genauigkeit: "
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textSize="10sp" />
        <TextView
        android:id="@+id/textViewAccWert"
        android:layout_
        android:layout_
        android:text=""
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textSize="10sp" />
    </LinearLayout>
</LinearLayout>
<!--  
<org.osmdroid.views.MapView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/mapview"
    android:layout_
    android:layout_
    android:clickable="true"/>
-->

<LinearLayout
    android:id="@+id/trackingLinearLayoutMap"
    android:layout_
    android:layout_
    android:orientation="vertical" >

</LinearLayout>

希望对你有帮助!

【问题讨论】:

你能把完整的代码和 xml 发给你吗?r 用代码更新了我的问题。 【参考方案1】:

你永远不会相信这一点,但如果你前往How often can you update a textview without mess,你会发现一个我认为可以解决问题的问题和答案。

如果这些都不能解决问题,您可能需要将按钮替换为自定义视图,并使用 canvas.drawText() 覆盖 onDraw 以放置文本。然后,您可以确保清除任何以前的历史记录...

如果您只想要一个不透明的黑色背景,请在您的 res 目录中创建(或添加)colors.xml 文件:

<resources>
    <color name="black">#ff000000</color>
</resources>

并添加:

    android:background="@color/black"

到 TextView 的 xml。

【讨论】:

太棒了,这是同样的问题。非常感谢! 这很奇怪!没听说过!还有另一种方法可以检查此问题。尝试删除线性布局内的所有其他文本视图。也许其中一个覆盖在另一个之上。 @Udioshi 这总是值得检查的,但在我所指的问题中并非如此...... @UdiOshi :我删除了除一个之外的所有 TextView,但出现了相同的效果。 我仍然认为最好的方法是通过将其外部包含视图转换为 ViewGroup 来动态加载 Widget。在这里查看我的答案***.com/questions/22362360/…【参考方案2】:

中的android:text=""
    <TextView
    android:id="@+id/textViewLonWert"
    android:layout_
    android:layout_
    android:text=""
    android:textAppearance="?android:attr/textAppearanceSmall"
    android:textSize="10sp" />

是多余的,你可以删除那行。

【讨论】:

这不是原始问题的答案。最好作为评论来代替。

以上是关于Android TextView setText 覆盖之前的Text的主要内容,如果未能解决你的问题,请参考以下文章

Android TextView setText 覆盖之前的Text

Android TextView : “Do not concatenate text displayed with setText”

异步任务尝试调用虚拟方法'void android.widget.TextView.setText(java.lang.CharSequence)'[重复]

TextView 上的 setText 将覆盖以前的文本

Android TextView setText内嵌html标签

android-TextView setText在Html.fromHtml中显示图像和文本[重复]