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其它相關文章!

推薦閱讀: