Android實現文字消除效果
今天和大傢分享一個如何從右到左消除文本的動畫。
先看效果圖:
由於項目和語音識別相關,有時候人在不經意間交流的無效音頻會被識別出來,並展示於界面,為瞭美觀,客戶要求我們將這些無效的識別文本用一個從右到左的動畫給清除,於是便有瞭下述的技術實現。
嗯,效果做完後發現原理及其簡單,僅此記錄一下。
1、layout文件先在這兒貼一下
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <TextView android:layout_width="wrap_content" android:layout_height="44dp" android:text="百日不到處,青春恰自來。苔花如米小,也學牡丹開。" android:ellipsize="none" android:singleLine="true" android:background="#ff00ff" android:layout_marginTop="10dp" android:id="@+id/tv_text"/> <Button android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/btn_click" android:text="點擊清除"/> <Button android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/btn_click1" android:text="點擊恢復"/> </LinearLayout>
btn_click1是為瞭演示方便而設計的,可不計考慮。註意TextView中需要:
android:ellipsize="none" android:singleLine="true"
兩個屬性,該效果隻針對一行的文本。
2、貼一下java代碼
public class MainActivity extends AppCompatActivity { private TextView textView; private Button btn_click; private Button btn_click1; private Handler mHandler; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mHandler = new Handler(); textView = findViewById(R.id.tv_text); btn_click = findViewById(R.id.btn_click); btn_click1 = findViewById(R.id.btn_click1); btn_click.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { showAsrAnim(); } }); btn_click1.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { textView.setVisibility(View.VISIBLE); textView.setText("百日不到處,青春恰自來" +"苔花如米小,也學牡丹開。"); } }); } private void showAsrAnim() { mHandler.post(new Runnable() { @Override public void run() { //在這裡我們利用ValueAnimator.ofInt創建瞭一個值從textView的寬度到2的動畫,動畫時長是400ms,然後讓動畫開始 //第一步:創建ValueAnimator實例 ValueAnimator animator = ValueAnimator.ofInt(textView.getWidth(), 2); animator.setInterpolator(new LinearInterpolator()); animator.setDuration(4000); //第二步:添加監聽 animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animation) { //獲取ValueAnimator在運動時,當前運動點的值 int width = (int) animation.getAnimatedValue(); changeLayout(width); if (width == 2) { textView.setText(""); textView.setVisibility(View.INVISIBLE); ViewGroup.LayoutParams params = textView.getLayoutParams(); params.width = ViewGroup.LayoutParams.WRAP_CONTENT; textView.setLayoutParams(params); } } }); animator.start(); } }); } private void changeLayout(int width) { ViewGroup.LayoutParams params = textView.getLayoutParams(); params.width = width; textView.setLayoutParams(params); }} }
代碼中已經有瞭註釋,創建一個ValueAnimator實例,添加監聽,通過運動改變TextView的寬度,當達到最小寬度2dp時將文本設置為空且不可見,從而實現該功能。
以上就是Android實現文字消除效果的詳細內容,更多關於Android 文字消除效果的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- Android使用setContentView實現頁面的轉換效果
- Android studio實現簡易的計算器功能
- Android生成隨機數的方法實例
- Android文本視圖TextView實現跑馬燈效果
- Android自定義彈窗提示效果