
本文实例为大家分享了scrollVIEw实现顶部图片下拉放大的具体代码,供大家参考,具体内容如下
之前的scrollVIEw顶部图片下拉放大在之后的项目用到了几次,但没次都写在Activity中很麻烦,也不方便复用。这几天有空,所以重新使用自定义scrollVIEw的方法实现这个效果。原理和之前的基本是一致的,所以也不多说了,直接上代码。
package com.example.myapplication.dropzoom; import androID.animation.ObjectAnimator; import androID.animation.ValueAnimator; import androID.content.Context; import androID.util.AttributeSet; import androID.vIEw.MotionEvent; import androID.vIEw.VIEw; import androID.vIEw.VIEwGroup; import androID.Widget.ScrollVIEw; /** * Created by liujinhua on 2016/3/25. * 下拉放大scrollVIEw */ public class DropZoomScrollVIEw extends ScrollVIEw implements VIEw.OntouchListener { // 记录首次按下位置 private float mFirstposition = 0; // 是否正在放大 private Boolean mScaling = false; private VIEw dropZoomVIEw; private int dropZoomVIEwWIDth; private int dropZoomVIEwHeight; public DropZoomScrollVIEw(Context context) { super(context); } public DropZoomScrollVIEw(Context context,AttributeSet attrs) { super(context,attrs); } public DropZoomScrollVIEw(Context context,AttributeSet attrs,int defStyleAttr) { super(context,attrs,defStyleAttr); } @OverrIDe protected voID onFinishInflate() { super.onFinishInflate(); init(); } @OverrIDe protected voID onMeasure(int wIDthMeasureSpec,int heightmeasureSpec) { super.onMeasure(wIDthMeasureSpec,heightmeasureSpec); } private voID init() { setoverScrollMode(OVER_SCRolL_NEVER); if (getChildAt(0) != null) { VIEwGroup vg = (VIEwGroup) getChildAt(0); if (vg.getChildAt(0) != null) { dropZoomVIEw = vg.getChildAt(0); setontouchListener(this); } } } @OverrIDe public boolean ontouch(VIEw v,MotionEvent event) { if (dropZoomVIEwWIDth <= 0 || dropZoomVIEwHeight <= 0) { dropZoomVIEwWIDth = dropZoomVIEw.getMeasureDWIDth(); dropZoomVIEwHeight = dropZoomVIEw.getMeasuredHeight(); } switch (event.getAction()) { case MotionEvent.ACTION_UP: //手指离开后恢复图片 mScaling = false; replyImage(); break; case MotionEvent.ACTION_MOVE: if (!mScaling) { if (getScrollY() == 0) { mFirstposition = event.getY();// 滚动到顶部时记录位置,否则正常返回 } else { break; } } int distance = (int) ((event.getY() - mFirstposition) * 0.6); // 滚动距离乘以一个系数 if (distance < 0) { // 当前位置比记录位置要小,正常返回 break; } // 处理放大 mScaling = true; setZoom(1 + distance); return true; // 返回true表示已经完成触摸事件,不再处理 } return false; } // 回d动画 (使用了属性动画) public voID replyImage() { final float distance = dropZoomVIEw.getMeasureDWIDth() - dropZoomVIEwWIDth; // 设置动画 ValueAnimator anim = ObjectAnimator.offloat(0.0F,1.0F).setDuration((long) (distance * 0.7)); anim.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @OverrIDe public voID onAnimationUpdate(ValueAnimator animation) { float cVal = (float) animation.getAnimatedValue(); setZoom(distance - ((distance) * cVal)); } }); anim.start(); } //缩放 public voID setZoom(float s) { if (dropZoomVIEwHeight <= 0 || dropZoomVIEwWIDth <= 0) { return; } VIEwGroup.LayoutParams lp = dropZoomVIEw.getLayoutParams(); lp.wIDth = (int) (dropZoomVIEwWIDth + s); lp.height = (int) (dropZoomVIEwHeight * ((dropZoomVIEwWIDth + s) / dropZoomVIEwWIDth)); dropZoomVIEw.setLayoutParams(lp); } } 使用的时候也十分的简单
<?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"> <com.example.myapplication.dropzoom.DropZoomScrollVIEw androID:layout_wIDth="match_parent" androID:layout_height="match_parent"> <linearLayout androID:layout_wIDth="match_parent" androID:layout_height="wrap_content" androID:orIEntation="vertical"> <ImageVIEw androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:layout_gravity="center" androID:src="@drawable/bg" /> <ImageVIEw androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:layout_gravity="center" androID:src="@drawable/home_bg" /> <ImageVIEw androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:layout_gravity="center" androID:src="@drawable/home_bg" /> <ImageVIEw androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:layout_gravity="center" androID:src="@drawable/home_bg" /> <ImageVIEw androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:layout_gravity="center" androID:src="@drawable/home_bg" /> </linearLayout> </com.example.myapplication.dropzoom.DropZoomScrollVIEw> </linearLayout>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。
以上是内存溢出为你收集整理的Android自定义scrollView实现顶部图片下拉放大全部内容,希望文章能够帮你解决Android自定义scrollView实现顶部图片下拉放大所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)