Android實現(xiàn)背景圖滑動變大松開回彈效果
更新時間:2022年04月18日 17:00:41 作者:“嗯哈
這篇文章主要為大家詳細介紹了Android實現(xiàn)背景圖滑動變大松開回彈效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了Android實現(xiàn)背景圖滑動變大松開回彈的具體代碼,供大家參考,具體內容如下
原圖

放大后

1、自定義view繼承ScrollView實現(xiàn)效果
public class HeadZoomScrollView extends ScrollView {
? ? private View mZoomView;
? ? private int mZoomViewWidth;
? ? private int mZoomViewHeight;
? ? private float firstPosition;//記錄第一次按下的位置
? ? private boolean isScrolling;//是否正在縮放
? ? private float mScrollRate = 0.3f;//縮放系數(shù),縮放系數(shù)越大,變化的越大
? ? private float mReplyRate = 0.5f;//回調系數(shù),越大,回調越慢
? ? public HeadZoomScrollView(Context context) {
? ? ? ? super(context);
? ? }
? ? public HeadZoomScrollView(Context context, AttributeSet attrs) {
? ? ? ? super(context, attrs);
? ? }
? ? public HeadZoomScrollView(Context context, AttributeSet attrs, int defStyleAttr) {
? ? ? ? super(context, attrs, defStyleAttr);
? ? }
? ? public void setmZoomView(View mZoomView) {
? ? ? ? this.mZoomView = mZoomView;
? ? }
? ? public void setmScrollRate(float mScrollRate) {
? ? ? ? this.mScrollRate = mScrollRate;
? ? }
? ? public void setmReplyRate(float mReplyRate) {
? ? ? ? this.mReplyRate = mReplyRate;
? ? }
? ? @Override
? ? protected void onFinishInflate() {
? ? ? ? super.onFinishInflate();
? ? ? ? init();
? ? }
? ? private void init() {
? ? ? ? setOverScrollMode(OVER_SCROLL_NEVER);
? ? ? ? if (getChildAt(0) != null) {
? ? ? ? ? ? ViewGroup vg = (ViewGroup) getChildAt(0);
? ? ? ? ? ? if (vg.getChildAt(0) != null) {
? ? ? ? ? ? ? ? mZoomView = vg.getChildAt(0);
? ? ? ? ? ? }
? ? ? ? }
? ? }
? ? @Override
? ? public boolean onTouchEvent(MotionEvent ev) {
? ? ? ? if (mZoomViewWidth <= 0 || mZoomViewHeight <= 0) {
? ? ? ? ? ? mZoomViewWidth = mZoomView.getMeasuredWidth();
? ? ? ? ? ? mZoomViewHeight = mZoomView.getMeasuredHeight();
? ? ? ? }
? ? ? ? switch (ev.getAction()) {
? ? ? ? ? ? case MotionEvent.ACTION_UP:
? ? ? ? ? ? ? ? //手指離開后恢復圖片
? ? ? ? ? ? ? ? isScrolling = false;
? ? ? ? ? ? ? ? replyImage();
? ? ? ? ? ? ? ? break;
? ? ? ? ? ? case MotionEvent.ACTION_MOVE:
? ? ? ? ? ? ? ? if (!isScrolling) {
? ? ? ? ? ? ? ? ? ? if (getScrollY() == 0) {
? ? ? ? ? ? ? ? ? ? ? ? firstPosition = ev.getY();// 滾動到頂部時記錄位置,否則正常返回
? ? ? ? ? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? ? ? ? ? break;
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? int distance = (int) ((ev.getY() - firstPosition) * mScrollRate); // 滾動距離乘以一個系數(shù)
? ? ? ? ? ? ? ? if (distance < 0) { // 當前位置比記錄位置要小,正常返回
? ? ? ? ? ? ? ? ? ? break;
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? // 處理放大
? ? ? ? ? ? ? ? isScrolling = true;
? ? ? ? ? ? ? ? setZoom(distance);
? ? ? ? ? ? ? ? return true; // 返回true表示已經完成觸摸事件,不再處理
? ? ? ? }
? ? ? ? return true;
? ? }
? ? //回彈動畫
? ? private void replyImage() {
? ? ? ? float distance = mZoomView.getMeasuredWidth() - mZoomViewWidth;
? ? ? ? ValueAnimator valueAnimator = ValueAnimator.ofFloat(distance, 0f).setDuration((long) (distance * mReplyRate));
? ? ? ? valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
? ? ? ? ? ? @Override
? ? ? ? ? ? public void onAnimationUpdate(ValueAnimator animation) {
? ? ? ? ? ? ? ? setZoom((Float) animation.getAnimatedValue());
? ? ? ? ? ? }
? ? ? ? });
? ? ? ? valueAnimator.start();
? ? }
? ? public void setZoom(float zoom) {
? ? ? ? if (mZoomViewWidth <= 0 || mZoomViewHeight <= 0) {
? ? ? ? ? ? return;
? ? ? ? }
? ? ? ? ViewGroup.LayoutParams lp = mZoomView.getLayoutParams();
? ? ? ? lp.width = (int) (mZoomViewWidth + zoom);
? ? ? ? lp.height = (int) (mZoomViewHeight * ((mZoomViewWidth + zoom) / mZoomViewWidth));
? ? ? ? ((MarginLayoutParams) lp).setMargins(-(lp.width - mZoomViewWidth) / 2, 0, -(lp.width - mZoomViewWidth) / 2, 0);
? ? ? ? mZoomView.setLayoutParams(lp);
? ? }
}2、直接布局中使用這個view就可以,要注意的是在布局中需要在自定義view下寫一個子控件才能使用
<?xml version="1.0" encoding="utf-8"?> <你的包名.HeadZoomScrollView 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:id="@+id/drop_down_menu" ? ? android:layout_width="match_parent" ? ? android:layout_height="match_parent" ? ?> ? ? <RelativeLayout ? ? ? ? android:layout_width="match_parent" ? ? ? ? android:layout_height="match_parent"> ? ? ? ? <ImageView ? ? ? ? ? ? android:id="@+id/iv_show" ? ? ? ? ? ? android:layout_width="match_parent" ? ? ? ? ? ? android:layout_height="200dp" ? ? ? ? ? ? android:layout_weight="1" ? ? ? ? ? ? android:src="@mipmap/ic_launcher"/> ? ? </RelativeLayout> </com.example.application.view.HeadZoomScrollView>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- Android基于reclyview實現(xiàn)列表回彈動畫效果
- Android?ScrollView實現(xiàn)滾動超過邊界松手回彈
- android ScrollView實現(xiàn)水平滑動回彈
- Android實現(xiàn)橡皮筋回彈和平移縮放效果
- Android自定義View實現(xiàn)豎向滑動回彈效果
- android實現(xiàn)可上下回彈的scrollview
- Android實現(xiàn)回彈ScrollView的原理
- Android自定義實現(xiàn)可回彈的ScollView
- Android ScrollView的頂部下拉和底部上拉回彈效果
- android自定義滾動上下回彈scollView
相關文章
mac開發(fā)android環(huán)境搭建步驟圖解
這里比較詳細的來總結下mac開發(fā)android的環(huán)境搭建步驟安裝過程,希望對一些正準備配置Android開發(fā)環(huán)境的小伙伴們有一定幫助2014-01-01
Android studio gradle環(huán)境變量配置教程
這篇文章主要為大家詳細介紹了Android studio gradle環(huán)境變量配置教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-05-05
Android界面設計(APP設計趨勢 左側隱藏菜單右邊顯示content)
這文章講述了2013年未來的移動APP設計趨勢,感覺挺有道理的:Android界面設計實現(xiàn)左側隱藏菜單右邊顯示content,感興趣的你可以了解下啊,希望本文對你的APP設計提高有所幫助哦2013-01-01
Andriod Service與Thread的區(qū)別介紹
我們要明確Service是運行在主線程的,不能有耗時操作,這樣,在Service中處理耗時操作的時候,我們依然需要使用線程來處理,既然在Service里也要創(chuàng)建一個子線程,那為什么不直接在Activity里創(chuàng)建呢,下面通過本文給大家介紹Andriod Service與Thread的區(qū)別,一起看看吧2017-04-04
Android中監(jiān)聽軟鍵盤顯示狀態(tài)實現(xiàn)代碼
這篇文章主要介紹了Android中監(jiān)聽軟鍵盤顯示狀態(tài)實現(xiàn)代碼,本文直接給出核心實現(xiàn)代碼,需要的朋友可以參考下2015-04-04

