这篇文章主要讲解了“怎么用Android实现文字消除效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用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实现文字消除效果这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。