編輯:關於Android編程
Android UI更新
做過Android開發的人都遇到過這樣的問題:隨著需求的變化,某些入口界面會出現UI的增減、內容變化和跳轉界面變化等問題,這裡就說明幾種方法來實現 UI的更新。
1、Activity的 runOnUiThread
textView = (TextView) findViewById( R.id.tv ); new Thread(new Runnable() { @Override public void run() { runOnUiThread(new Runnable() { @Override public void run() { textView.setText( "更新UI了"); } }); } }).start();
android Activity runOnUiThread() 方法使用
2、Handler sendEmptyMessage()
package lib.com.myapplication; import android.os.Handler; import android.os.Message; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.widget.TextView; public class MainActivity extends AppCompatActivity { private TextView textView ; Handler handler = new Handler( ) { @Override public void handleMessage(Message msg) { super.handleMessage(msg); textView.setText( "Ui更新了"); } }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); textView = (TextView) findViewById( R.id.tv ); new Thread(new Runnable() { @Override public void run() { try { Thread.sleep( 2000 ); } catch (InterruptedException e) { e.printStackTrace(); } handler.sendEmptyMessage( 2 ) ; } }).start(); } }
3、Handler post()
package lib.com.myapplication; import android.os.Bundle; import android.os.Handler; import android.support.v7.app.AppCompatActivity; import android.widget.TextView; public class MainActivity extends AppCompatActivity { private TextView textView ; Handler handler = new Handler(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); textView = (TextView) findViewById( R.id.tv ); new Thread(new Runnable() { @Override public void run() { try { Thread.sleep( 2000 ); } catch (InterruptedException e) { e.printStackTrace(); } handler.post(new Runnable() { @Override public void run() { textView.setText( "Ui更新了"); } }) ; } }).start(); } }
在子線程中切換到主線程
new Thread(new Runnable() { @Override public void run() { LogUtil.d( "ttt 11111111111" + Thread.currentThread().getName() ); new Handler(Looper.getMainLooper()).post(new Runnable() { @Override public void run() { LogUtil.d( "ttt 55555555" + Thread.currentThread().getName() ); } }); LogUtil.d( "ttt 22222222222" + Thread.currentThread().getName() ); LogUtil.d( "ttt 33333333333" + Thread.currentThread().getName() ); LogUtil.d( "ttt 44444444444" + Thread.currentThread().getName() ); } }).start();
結果
ttt 11111111111Thread-155 ttt 22222222222Thread-155 ttt 33333333333Thread-155 ttt 44444444444Thread-155 ttt 55555555main
可見這種方式可以快速切換線程,從log日志來看,切換到主線程不會阻塞子線程。
4、view Post()
textView = (TextView) findViewById( R.id.tv ); new Thread(new Runnable() { @Override public void run() { try { Thread.sleep( 2000 ); } catch (InterruptedException e) { e.printStackTrace(); } textView.post(new Runnable() { @Override public void run() { textView.setText( "Ui更新了"); } }) ; } }).start();
總結:
1、其實上面的四種方式都可歸結於一種方式:handler 用於Android線程之間的通信。
2、為什麼android要求只能在UI線程進行UI操作? 主要還是為了避免多線程造成的並發的問題。在單線程操作UI是安全的。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
筆者最近一直忙於滿廣州的跑,實習好難找好難找,博客也是有點久沒去更新。仿360手機衛士的實現的目的更多的是出於對常用知識點的一個鞏固吧,比較適合像我這種接觸沒多久的學習者
介紹有時候由於需要一些自定義之後的開源庫,無法使用jCenter裡面的官方庫,又懶得自己搭建Maven倉庫,所以我們想要自己在項目裡面直接導入本地的AAR庫。通用方法和問
前言學習了以上的文章後,接下來我們來講講自定義View,自定義View一直被認為是高手掌握的技能,因為情況太多,想實現的效果又變化多端,但它也要遵循一定的規則,我們要講的
引言我們在android的APP開發中有時候會碰到提供一個選項列表供用戶選擇的需求,如在投票類型的項目中,我們提供一些主題給用戶選擇,每個主題有若干選項,用戶對這些主題的