欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android實(shí)現(xiàn)文字消除效果

 更新時(shí)間:2021年06月24日 09:22:21   作者:蘿卜棗  
由于項(xiàng)目和語(yǔ)音識(shí)別相關(guān),有時(shí)候人在不經(jīng)意間交流的無(wú)效音頻會(huì)被識(shí)別出來(lái),并展示于界面,為了美觀,客戶要求我們將這些無(wú)效的識(shí)別文本用一個(gè)從右到左的動(dòng)畫給清除,于是便有了下述的技術(shù)實(shí)現(xiàn)。感興趣的朋友可以參考下

今天和大家分享一個(gè)如何從右到左消除文本的動(dòng)畫。

先看效果圖:

由于項(xiàng)目和語(yǔ)音識(shí)別相關(guān),有時(shí)候人在不經(jīng)意間交流的無(wú)效音頻會(huì)被識(shí)別出來(lái),并展示于界面,為了美觀,客戶要求我們將這些無(wú)效的識(shí)別文本用一個(gè)從右到左的動(dòng)畫給清除,于是便有了下述的技術(shù)實(shí)現(xiàn)。

嗯,效果做完后發(fā)現(xiàn)原理及其簡(jiǎn)單,僅此記錄一下。

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="百日不到處,青春恰自來(lái)。苔花如米小,也學(xué)牡丹開。"
        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="點(diǎn)擊清除"/>
        
  <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/btn_click1"
        android:text="點(diǎn)擊恢復(fù)"/>
</LinearLayout>

btn_click1是為了演示方便而設(shè)計(jì)的,可不計(jì)考慮。注意TextView中需要:

android:ellipsize="none"
android:singleLine="true"

兩個(gè)屬性,該效果只針對(duì)一行的文本。

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("百日不到處,青春恰自來(lái)" +"苔花如米小,也學(xué)牡丹開。");
            }
        });
    }

    private void showAsrAnim() {
        mHandler.post(new Runnable() {
            @Override
            public void run() {
                //在這里我們利用ValueAnimator.ofInt創(chuàng)建了一個(gè)值從textView的寬度到2的動(dòng)畫,動(dòng)畫時(shí)長(zhǎng)是400ms,然后讓動(dòng)畫開始
                //第一步:創(chuàng)建ValueAnimator實(shí)例
                ValueAnimator animator = ValueAnimator.ofInt(textView.getWidth(), 2);
                animator.setInterpolator(new LinearInterpolator());
                animator.setDuration(4000);

                //第二步:添加監(jiān)聽
                animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
                    @Override
                    public void onAnimationUpdate(ValueAnimator animation) {
                        //獲取ValueAnimator在運(yùn)動(dòng)時(shí),當(dāng)前運(yùn)動(dòng)點(diǎn)的值
                        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);
    }}
}

代碼中已經(jīng)有了注釋,創(chuàng)建一個(gè)ValueAnimator實(shí)例,添加監(jiān)聽,通過(guò)運(yùn)動(dòng)改變TextView的寬度,當(dāng)達(dá)到最小寬度2dp時(shí)將文本設(shè)置為空且不可見,從而實(shí)現(xiàn)該功能。

以上就是Android實(shí)現(xiàn)文字消除效果的詳細(xì)內(nèi)容,更多關(guān)于Android 文字消除效果的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Android為View添加拖放效果的方法實(shí)例

    Android為View添加拖放效果的方法實(shí)例

    這篇文章主要給大家介紹了關(guān)于Android為View添加拖放效果的相關(guān)資料,實(shí)現(xiàn)View的拖拽其實(shí)原理很簡(jiǎn)單,無(wú)非就是獲取手指的位移信息,然后view根據(jù)手指的位移信息,移動(dòng)對(duì)應(yīng)的位置,需要的朋友可以參考下
    2022-02-02
  • android彈出activity設(shè)置大小的方法

    android彈出activity設(shè)置大小的方法

    本篇文章介紹了android彈出activity設(shè)置大小的方法,需要的朋友可以參考一下
    2013-06-06
  • Android 8.0中一些坑以及對(duì)應(yīng)的解決方法

    Android 8.0中一些坑以及對(duì)應(yīng)的解決方法

    這篇文章主要給大家介紹了關(guān)于Android 8.0中一些坑以及對(duì)應(yīng)的解決方法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-09-09
  • Android使用ViewPager實(shí)現(xiàn)頂部tabbar切換界面

    Android使用ViewPager實(shí)現(xiàn)頂部tabbar切換界面

    這篇文章主要為大家詳細(xì)介紹了使用ViewPager實(shí)現(xiàn)頂部tabbar切換界面,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Jetpack Compose布局的使用詳細(xì)介紹

    Jetpack Compose布局的使用詳細(xì)介紹

    Jetpack Compose是用于構(gòu)建原生Android界面的新工具包。它可簡(jiǎn)化并加快Android上的界面開發(fā),使用更少的代碼、強(qiáng)大的工具和直觀的 Kotlin API,快速讓應(yīng)用生動(dòng)而精彩
    2022-09-09
  • Android實(shí)現(xiàn)拍照、錄像、錄音代碼范例

    Android實(shí)現(xiàn)拍照、錄像、錄音代碼范例

    這篇文章主要介紹了Android實(shí)現(xiàn)拍照、錄像、錄音代碼的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2016-10-10
  • Android webview實(shí)現(xiàn)拍照的方法

    Android webview實(shí)現(xiàn)拍照的方法

    這篇文章主要介紹了Android webview實(shí)現(xiàn)拍照的方法的相關(guān)資料,希望通過(guò)本文能幫助到大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下
    2017-10-10
  • Android性能優(yōu)化方法

    Android性能優(yōu)化方法

    這篇文章主要介紹了Android性能優(yōu)化方法 的相關(guān)資料,需要的朋友可以參考下
    2015-12-12
  • Android實(shí)現(xiàn)拍照及圖片顯示效果

    Android實(shí)現(xiàn)拍照及圖片顯示效果

    這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)拍照及圖片顯示效果 ,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • Android編程之語(yǔ)音識(shí)別實(shí)現(xiàn)方法

    Android編程之語(yǔ)音識(shí)別實(shí)現(xiàn)方法

    這篇文章主要介紹了Android編程語(yǔ)音識(shí)別實(shí)現(xiàn)方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了Android語(yǔ)音識(shí)別的操作步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2016-10-10

最新評(píng)論