android 自定义滚动上下回弹scollView
来源:互联网 发布:上海高通待遇 知乎 编辑:程序博客网 时间:2024/05/21 19:31
这是一个自定义view,在xml布局中用这个view嵌套要使之可以上下回弹的view,
就能实现布局可以滚动上下回弹了,自定义view代码如下:
package com.loopfire.meitaotao.view.scrollView;import android.content.Context;import android.graphics.Rect;import android.util.AttributeSet;import android.view.MotionEvent;import android.view.View;import android.view.animation.Animation;import android.view.animation.Animation.AnimationListener;import android.view.animation.TranslateAnimation;import android.widget.ScrollView;/** * 上下回弹 scollView * * @author Administrator * */public class MyScrollView extends ScrollView {private View inner;private float y;private Rect normal = new Rect();private boolean animationFinish = true;public MyScrollView(Context context) {super(context);}public MyScrollView(Context context, AttributeSet attrs) {super(context, attrs);}@Overrideprotected void onFinishInflate() {if (getChildCount() > 0) {inner = getChildAt(0);}}@Overridepublic boolean onInterceptTouchEvent(MotionEvent ev) {return super.onInterceptTouchEvent(ev);}@Overridepublic boolean onTouchEvent(MotionEvent ev) {if (inner == null) {return super.onTouchEvent(ev);} else {commOnTouchEvent(ev);}return super.onTouchEvent(ev);}private void commOnTouchEvent(MotionEvent ev) {if (animationFinish) {int action = ev.getAction();switch (action) {case MotionEvent.ACTION_DOWN:// System.out.println("ACTION_DOWN");y = ev.getY();super.onTouchEvent(ev);break;case MotionEvent.ACTION_UP:// System.out.println("ACTION_UP");y = 0;if (isNeedAnimation()) {animation();}super.onTouchEvent(ev);break;case MotionEvent.ACTION_MOVE:// System.out.println("ACTION_MOVE");final float preY = y == 0 ? ev.getY() : y;float nowY = ev.getY();int deltaY = (int) (preY - nowY);// 滚动// scrollBy(0, deltaY);y = nowY;// 当滚动到最上或者最下时就不会再滚动,这时移动布局if (isNeedMove()) {if (normal.isEmpty()) {// 保存正常的布局位置normal.set(inner.getLeft(), inner.getTop(), inner.getRight(), inner.getBottom());}// 移动布局inner.layout(inner.getLeft(), inner.getTop() - deltaY / 2, inner.getRight(), inner.getBottom() - deltaY / 2);} else {super.onTouchEvent(ev);}break;default:break;}}}// 开启动画移动private void animation() {// 开启移动动画TranslateAnimation ta = new TranslateAnimation(0, 0, 0, normal.top - inner.getTop());ta.setDuration(200);ta.setAnimationListener(new AnimationListener() {@Overridepublic void onAnimationStart(Animation animation) {animationFinish = false;}@Overridepublic void onAnimationRepeat(Animation animation) {}@Overridepublic void onAnimationEnd(Animation animation) {inner.clearAnimation();// 设置回到正常的布局位置inner.layout(normal.left, normal.top, normal.right, normal.bottom);normal.setEmpty();animationFinish = true;}});inner.startAnimation(ta);}// 是否需要开启动画private boolean isNeedAnimation() {return !normal.isEmpty();}// 是否需要移动布局private boolean isNeedMove() {int offset = inner.getMeasuredHeight() - getHeight();int scrollY = getScrollY();if (scrollY == 0 || scrollY == offset) {return true;}return false;}}
在xml中使用如下:
<com.loopfire.meitaotao.view.scrollView.MyScrollView> <TextView style="@style/form_left_text_style" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="@dimen/text_margin_left2" android:text="@string/about" /> </com.loopfire.meitaotao.view.scrollView.MyScrollView>
那么包含的这个textview可以上下滚动并且回弹了
0 0
- android 自定义滚动上下回弹scollView
- 【Android】高仿QQ的上下回弹效果之自定义的ScrollView
- android textView 上下滚动
- 上下滚动文字自定义控件
- Android超简单实现listview上下拉伸回弹动画效果
- 自定义ScollView,根据ScollView滚动,改变头部搜索框,以及实现缓解用户焦虑整体布局移动
- 上下回弹动画
- 自定义ViewpagerIndicator (仿猫眼,添加边缘回弹滚动效果)
- Android:自定义ImageView实现缩放,回弹效果
- Android自定义View--ScrollView实现回弹效果
- android实现左右上下滚动
- android 页面文字上下滚动
- Android 实现上下滚动TextSwitcher
- Android 禁止RecyclerView 上下滚动
- 自定义View--单行上下滚动广告
- Android自定义View(LimitScrollerView-仿天猫广告栏上下滚动效果)
- Android View滚动、拉伸到顶/底部弹性回弹复位
- Android View滚动、拉伸到顶/底部弹性回弹复位
- LeetCode203——Remove Linked List Elements
- Android onTouchEvent, onClick及onLongClick的调用机制
- Spring JdbcTemplate框架(二)——动态建表
- 20个设计模式和软件设计面试问题
- 从图割到图像分割 - 最大流算法
- android 自定义滚动上下回弹scollView
- Android中实现视频全屏播放
- 从图割到图像分割 - 图的构造
- Friend, Season 1, episode 1
- MFC透明图标
- Python实现类似局域网QQ群聊
- 从图割到图像分割 - 多层图图割
- MFC添加背景音乐
- MFC生成release文件