文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Android开发中利用ListView实现一个渐变式的下拉刷新动画

2023-05-31 12:37

关注

本篇文章给大家分享的是有关Android开发中利用ListView实现一个渐变式的下拉刷新动画,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

主要要点

listview刷新过程中主要有三个步骤当前:状态为下拉刷新,当前状态为下拉刷新,当前状态为放开刷新,当前状态为正在刷新;主要思路为三个步骤分别对应三个自定义的view;即ibuRefreshFirstStepView,ibuRefreshSecondStepView,ibuRefreshThirdStepView。

效果图

Android开发中利用ListView实现一个渐变式的下拉刷新动画

ibuRefreshFirstStepView代码,例如:

 private Bitmap initialBitmap; private float mCurrentProgress; private Bitmap scaledBitmap; public ibuRefreshFirstStepView(Context context, AttributeSet attrs,         int defStyle) {  super(context, attrs, defStyle);  init(context); } public ibuRefreshFirstStepView(Context context, AttributeSet attrs) {  super(context, attrs);  init(context); } public ibuRefreshFirstStepView(Context context) {  super(context);  init(context); } private void init(Context context) {  //这个就是那个火箭图片  initialBitmap = Bitmap.createBitmap(BitmapFactory.decodeResource(getResources(), R.drawable.img_huojian1)); }  @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {  //根据设置的宽度来计算高度 设置为符合第二阶段娃娃图片的宽高比例  setMeasuredDimension(measureWidth(widthMeasureSpec),measureWidth(widthMeasureSpec)*initialBitmap.getHeight()/initialBitmap.getWidth()); }  private int measureWidth(int widMeasureSpec){  int result = 0;  int size = MeasureSpec.getSize(widMeasureSpec);  int mode = MeasureSpec.getMode(widMeasureSpec);  if (mode == MeasureSpec.EXACTLY){   result = size;  }else{   result = initialBitmap.getWidth();   if (mode == MeasureSpec.AT_MOST){    result = Math.min(result,size);   }  }  return result;  }  @Override protected void onLayout(boolean changed, int left, int top, int right,   int bottom) {  super.onLayout(changed, left, top, right, bottom);  // 给火箭图片进行等比例的缩放  scaledBitmap = Bitmap.createScaledBitmap(initialBitmap,89,110, false); } @Override protected void onDraw(Canvas canvas) {  super.onDraw(canvas);  //这个方法是对画布进行缩放,从而达到椭圆形图片的缩放,第一个参数为宽度缩放比例,第二个参数为高度缩放比例,//  canvas.scale(mCurrentProgress, mCurrentProgress, measuredWidth/2, measuredHeight/2);  //将等比例缩放后的椭圆形画在画布上面  canvas.drawBitmap(scaledBitmap,90,dip2px(getContext(),80*mCurrentProgress),null); }  public static int dip2px(Context context, float dpValue) {  final float scale = context.getResources().getDisplayMetrics().density;  return (int) (dpValue * scale + 0.5f); }  public void setCurrentProgress(float currentProgress){  mCurrentProgress = currentProgress; }}

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 资料下载
  • 历年真题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯