需求场景:当我们在使用Progressbar的时候,希望有进度加载的效果,此时我们传统的做法是使用Thread线程来实现,下面我们用属性动画来实现,简单粗暴。。哈哈哈
布局文件:
<?xml version="1.0" enCoding="utf-8"?><linearLayout xmlns:androID="http://schemas.androID.com/apk/res/androID" xmlns:app="http://schemas.androID.com/apk/res-auto" xmlns:tools="http://schemas.androID.com/tools" androID:layout_wIDth="match_parent" androID:layout_height="match_parent" androID:orIEntation="vertical" tools:context="com.yhx.app.progressbardemo.MainActivity"> <Progressbar androID:layout_margintop="20dp" androID:ID="@+ID/bar" androID:layout_wIDth="match_parent" androID:layout_height="8dp" androID:progress="10" androID:max="100"> </Progressbar> <button androID:hint="开始" androID:onClick="show" androID:layout_margintop="50dp" androID:layout_wIDth="match_parent" androID:layout_height="50dp"/> <TextVIEw androID:ID="@+ID/tv_bar" androID:layout_margintop="20dp" androID:layout_wIDth="100dp" androID:text="0" androID:gravity="center" androID:textSize="38dp" androID:layout_gravity="center" androID:layout_height="100dp"/> <button androID:hint="开始" androID:onClick="tvshow" androID:layout_margintop="50dp" androID:layout_wIDth="match_parent" androID:layout_height="50dp"/></linearLayout>
Activity:
public class MainActivity extends AppCompatActivity { private Progressbar mProgressbar; TextVIEw mtv_bar; @OverrIDe protected voID onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentVIEw(R.layout.activity_main); mProgressbar = (Progressbar) findVIEwByID(R.ID.bar); mtv_bar = (TextVIEw) findVIEwByID(R.ID.tv_bar); setAnimation(mProgressbar,100); } private voID setAnimation(final Progressbar vIEw,final int mProgressbar) { ValueAnimator animator = ValueAnimator.ofInt(0,mProgressbar).setDuration(5000); animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @OverrIDe public voID onAnimationUpdate(ValueAnimator valueAnimator) { vIEw.setProgress((int) valueAnimator.getAnimatedValue()); } }); animator.start(); } private voID setTvAnimation(final TextVIEw vIEw,mProgressbar).setDuration(5000); animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @OverrIDe public voID onAnimationUpdate(ValueAnimator valueAnimator) { vIEw.setText(String.valueOf(valueAnimator.getAnimatedValue())); } }); animator.start(); } public voID show(VIEw vIEw) { setAnimation(mProgressbar,100); } public voID tvshow(VIEw vIEw){ setTvAnimation(mtv_bar,240); }}
效果图:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。
您可能感兴趣的文章:android ListView和ProgressBar(进度条控件)的使用方法Android三种方式实现ProgressBar自定义圆形进度条Android ProgressBar进度条和ProgressDialog进度框的展示DEMOAndroid ProgressBar进度条使用详解Android编程之ProgressBar圆形进度条颜色设置方法Android之ProgressBar即时显示下载进度详解Android编程实现自定义ProgressBar样式示例(背景色及一级、二级进度条颜色)Android ProgressBar直线进度条的实例代码Android编程实现类似于圆形ProgressBar的进度条效果Android开发之ProgressBar字体随着进度条的加载而滚动 总结以上是内存溢出为你收集整理的Android使用动画设置ProgressBar进度的方法全部内容,希望文章能够帮你解决Android使用动画设置ProgressBar进度的方法所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)