android微信朋友圈相册背景,Android 仿微信朋友圈图片拖拽返回

目前的app的动画效果是越来越炫了,很多主流app的图片预览返回都有类似功能,比较常见的是ios自带相册,微信朋友圈等等。自己项目中也有类似功能,最近整理了一下这个功能的代码,做个笔记记录,有兴趣的朋友可以点击源码。

网上已经有对应功能的三方库了,MyDragPhotoView 和 DragPhotoView等等。但是他们都是继承view去实现的。如果我想用到其他View/ViewGroup上,就不是很方便,需要重新自定义view,然后复制黏贴和修改。因此就有了这篇文章,这个效果可以加在任意View或者ViewGroup上。

效果图:

一般经常用到这个功能的,莫非就是图片预览和视频预览了。

视频控件效果

2d30934229e9

SVID_20190419_113022_123.gif

图片控件效果

2d30934229e9

SVID_20190515_151249_123.gif

使用步骤:

1.activity主题设为透明

true

2.初始化

DragCloseHelper dragCloseHelper = new DragCloseHelper(this);

3.如果是共享元素启动的页面,需要如下设置(强烈建议和共享元素一起使用,否则是没有灵魂的)

dragCloseHelper.setShareElementMode(true);

4.设置需要进行拖拽的View/ViewGroup,以及背景ViewGroup(必须要设置背景色)

dragCloseHelper.setDragCloseViews(parentV, childV);

5.设置监听

dragCloseHelper.setDragCloseListener(new DragCloseHelper.DragCloseListener() {

@Override

public boolean intercept() {

//默认false 不拦截。比如图片在放大状态,是不需要执行拖拽动画的等等。

return false;

}

@Override

public void dragStart() {

//拖拽开始。可以在此额外处理一些逻辑

}

@Override

public void dragging(float percent) {

//拖拽中。percent当前的进度,取值0-1,可以在此额外处理一些逻辑

}

@Override

public void dragCancel() {

//拖拽取消,会自动复原。可以在此额外处理一些逻辑

}

@Override

public void dragClose(boolean isShareElementMode) {

//拖拽关闭,如果是共享元素的页面,需要执行activity的onBackPressed方法,注意如果使用finish方法,则返回的时候没有共享元素的返回动画

if (isShareElementMode) {

onBackPressed();

}

}

});

6.处理touch事件

@Override

public boolean dispatchTouchEvent(MotionEvent event) {

if (dragCloseHelper.handleEvent(event)) {

return true;

} else {

return super.dispatchTouchEvent(event);

}

}

7.可以自定义最大拖拽距离和最小缩放尺寸

setMaxExitY(int maxExitY)

setMinScale(@FloatRange(from = 0.1f, to = 1.0f) float minScale)

原理:

很简单,就是touch事件传递,相信大家都已经滚瓜烂熟了。

大概步骤:

1.检测是否有拦截

2.ACTION_DOWN事件,初始化数据

3.ACTION_MOVE事件,如果多手指或者手指Id不一致,则复原,否则开始移动,同时更新拖拽View/ViewGroup的位置和大小。

4.ACTION_UP事件,判断是否超过指定的最大距离,如果超过,开始关闭动画,否则开始复原动画

核心代码如下:

/**

* 处理touch事件

*

* @param event

* @return

*/

public boolean handleEvent(MotionEvent event) {

if (dragCloseListener != null && dragCloseListener.intercept()) {

//拦截

isSwipingToClose = false;

return false;

} else {

//不拦截

if (event.getAction() == MotionEvent.ACTION_DOWN) {

//初始化数据

lastPointerId = event.getPointerId(0);

reset(event);

} else if (event.getAction() == MotionEvent.ACTION_MOVE) {

if (event.getPointerCount() > 1) {

//如果有多个手指

if (isSwipingToClose) {

//已经开始滑动关闭,恢复原状,否则需要派发事件

isSwipingToClose = false;

resetCallBackAnimation();

return true;

}

reset(event);

return false;

}

if (lastPointerId != event.getPointerId(0)) {

//手指不一致,恢复原状

if (isSwipingToClose) {

resetCallBackAnimation();

}

reset(event);

return true;

}

float currentY = event.getY();

float currentX = event.getX();

if (isSwipingToClose || Math.abs(currentY - mLastY) > 2 * viewConfiguration.getScaledTouchSlop()) {

//已经触发或者开始触发,更新view

mLastY = currentY;

mLastX = currentX;

float currentRawY = event.getRawY();

float currentRawX = event.getRawX();

if (!isSwipingToClose) {

//准备开始

isSwipingToClose = true;

if (dragCloseListener != null) {

dragCloseListener.dragStart();

}

}

//已经开始,更新view

mCurrentTranslationY = currentRawY - mLastRawY + mLastTranslationY;

mCurrentTranslationX = currentRawX - mLastRawX + mLastTranslationX;

float percent = 1 - Math.abs(mCurrentTranslationY / (maxExitY + childV.getHeight()));

if (percent > 1) {

percent = 1;

} else if (percent < 0) {

percent = 0;

}

parentV.getBackground().mutate().setAlpha((int) (percent * 255));

if (dragCloseListener != null) {

dragCloseListener.dragging(percent);

}

childV.setTranslationY(mCurrentTranslationY);

childV.setTranslationX(mCurrentTranslationX);

if (percent < minScale) {

percent = minScale;

}

childV.setScaleX(percent);

childV.setScaleY(percent);

return true;

}

} else if (event.getAction() == MotionEvent.ACTION_UP) {

//手指抬起事件

if (isSwipingToClose) {

if (mCurrentTranslationY > maxExitY) {

if (isShareElementMode) {

//会执行共享元素的离开动画

if (dragCloseListener != null) {

dragCloseListener.dragClose(true);

}

} else {

//会执行定制的离开动画

exitWithTranslation(mCurrentTranslationY);

}

} else {

resetCallBackAnimation();

}

isSwipingToClose = false;

return true;

}

} else if (event.getAction() == MotionEvent.ACTION_CANCEL) {

//取消事件

if (isSwipingToClose) {

resetCallBackAnimation();

isSwipingToClose = false;

return true;

}

}

}

return false;

}

衍生文章

在发布文章之后,有人提出在滑动返回的过程中,上一个页面的背景是空白的。对此特意写了篇文章Android 共享元素动画分析及背景空白的解决方案

这两个问题和DragCloseHelper这个库没有直接关联。不过看完这两篇衍生文章,相信你对共享元素动画的过程有一个全新的认识。

本文参考资料

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/566852.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python文本筛选html_python 正则表达式过滤文本中的html标签 源代码解析

#py2.7#coding:utf-8import reimport osimport chardetdef filter_tag(htmlstr):re_cdata re.compile(^>]*>, re.I)re_script re.compile(]*>[^, re.I) #过滤脚本re_style re.compile(]*>[^, re.I) #过滤stylere_br re.compile()re_h re.compile(?\w[^>]*…

erp采购总监个人总结_《用友 ERP 培训教程:财务核算/供应链管理/物料需求计划》ERP概述 : ERP基础知识...

第1章 ERP概述本章重点_- _ERP概要_- _ERP实施成功的必要条件_- _ERP几个重要的名词解释用友ERP-U8&#xff08;V8 .72&#xff09;简介及功能按钮说明1.1 ERP基础知识1.1.1 ERP基本概念ERP&#xff08;Enterprise Resources Planning&#xff09;中文叫做企业资源规划&…

android studio1.5 for mac,适用于Mac的Android Studio 1.5.x随机崩溃

适用于Mac的Android Studio 1.5(AI-141.2456560)经常随机崩溃.我正在使用Macbook Pro 15“Retina(2105年中期)和Mac OS X 10.11.1真的很烦人.你有过这些崩溃的经历吗&#xff1f;你知道任何解决方法吗&#xff1f;提前致谢.这是崩溃日志的标题&#xff1a;Process: studio [425…

python 八大排序_八大排序算法的 Python 实现

1、插入排序def insert_sort(lists):# 插入排序count len(lists)for i in range(1, count):key lists[i]j i - 1while j > 0:if lists[j] > key:lists[j 1] lists[j]lists[j] keyj - 1return lists2、希尔排序def shell_sort(lists):# 希尔排序count len(lists)st…

soc 设计soc设计 uml实务手册_企业内训“软件需求设计建模方法学全程实例剖析”训练方案(2020年)...

※训练介绍※利润需求-设计。软件开发中&#xff0c;需求是解决“系统怎样好卖”的问题&#xff0c;设计是解决“降低开发成本”的问题。要迈向“低成本制造好卖的产品”的境界&#xff0c;并非喊喊口号就能达到。口号&#xff1a;我们只做最重要的需求&#xff0c;尽快把系统推…

鸿蒙分布式通讯子系统,【鸿蒙】分布式通信子系统--让华为手机发现Hi3861开发板...

目录&#xff1a;工具步骤运行结果工具&#xff1a;1. 华为手机&#xff0c;需要有多设备协同功能。在设置->更多连接->多设备协同&#xff0c;查看是否有多设备协同功能&#xff0c;此功能使用的就是coap协议。2. Hi3861开发板步骤&#xff1a;1. 修改源码&#xff0c;…

python2.7 pyqt4创建qtapp_python-2.7 – 向TabWidget pyqt4添加加号按钮

以下代码提供了一个可以动态添加选项卡的选项卡界面import sys,randomfrom PyQt4 import QtCore,QtGuiclass TabContainer(QtGui.QWidget):def __init__(self):super(TabContainer,self).__init__()self.next_item_is_table Falseself.initUI()def initUI(self):self.setGeome…

html怎样在一张图片里写字,用HTML代码在图片上写字

效果一&#xff1a;文字居中cellSpacing0 cellPadding0 width410 aligncenterbackgroundhttp://bbs.guqu.net/UploadFile/2005-1/200512211045825.gifborder0> type"vertical" spacer>size7>百年爱情文字在图片中的位置。由中的aligncenter决定。center&…

winform 统计大量数据重复的元素个数_DAY10——推断统计之概率与概率分布:常见的离散型概率分布...

「数学期望——某件事情大量发生之后的平均结果」----------------分割又分割----------------------昨天文章排版出了问题&#xff0c;今天重新排版。数据的三个统计维度&#xff1a;集中程度、离散程度、分布情况。集中程度&#xff1a;期望离散程度&#xff1a;方差、标准差…

数组转换为html,如何将多维PHP数组转换为html表

我正在尝试使用多维数组变量制作一个HTML表&#xff0c;该变量$array2是一个查询(来自mysql数据库PHP查询而不是一个自制查询)&#xff0c;如下所示&#xff1b;Array([0] > Array([0] > M2TYEE[1] > Jean[2] > Harvey[3] > London[4] > 0314686334)[1] >…

xss跨站脚本攻击_常见攻击之xss跨站脚本攻击

前言随着互联网的不断发展&#xff0c;web应用的互动性也越来越强。相应的&#xff0c;在用户体验提升的同时安全风险也会跟着有所增加。今天&#xff0c;我们就来讲一讲web渗透中常见的攻击方式之一&#xff0c;XSS攻击。首先需要了解他是如何工作的&#xff0c;以及我们如何利…

android dropbox切换账户,android – 如何获取我的APP_KEY和SECRET_KEY的Dropbox同步?

我正在努力构建将应用程序的* .csv文件与理想的保管箱帐户同步的机会.我到目前为止做了什么>清单中的权限和com.dropbox.client2.android.AuthActivity>使用我的发行商店签署了我的应用程序>执行一些代码来检查保管箱服务问题是我不明白我在哪里可以得到APP_KEY和SECR…

缺陷调研报告_质量零缺陷 | 打造极致产品的质量管理之道

质量是政治质量是生命质量是效益为强化全员“零缺陷”质量意识&#xff0c;坚决打赢质量提升攻坚战&#xff0c;现开设“质量零缺陷”专栏&#xff0c;着力宣传全院各单位在加强质量管理&#xff0c;落实零缺陷理念等方面的典型做法和质量故事。今天为大家带来的是曾获得“全国…

html中隐藏单元格上边框,HTML table 标签边框问题(隐藏表格边框、单元格边框等)...

一、表格的常用属性基本属性有&#xff1a;width(宽度)、height(高度)、border(边框值)、cellspacing(表格的内宽&#xff0c;即表格与tr之间的间隔)、 cellpadding(表格内元素的间隔&#xff0c;即tr与tr之间的间隔)、bordercolorlight(表格的亮边框颜色)、 bordercolordark(表…

每日签到html特效,前端这种连续签到的效果要怎么写

后端返回数据&#xff1a; $data [month>2017-08,date>1,2,3,7,11]month: 当前月份&#xff1b;data:签到的日期;前端处理数据&#xff1a;首先根据date里返回的值将每个对应的日期给到class使其变亮&#xff0c;然后再在each中判断当前元素的上级元素是否为点亮状态&am…

oracle 从右往左截取_截取GIF、调分辨率、快捷拨号,三星这些功能让人爱不释手...

昨天三星5G手机正式上市后&#xff0c;今天又爆出苹果被三星拒绝后要转向华为购买5G芯片&#xff0c;苹果如此操作是真的走投无路了&#xff1f;再看看吃瓜群众们&#xff0c;吐槽一波接一波。​一会儿&#xff0c;嫌弃三星信号频段不完全&#xff0c;10nm的工艺制程太差。一会…

html编辑器查找与替换,织梦kindeditor文本编辑器增加“查找替换”功能

织梦kindeditor文本编辑器增加“查找替换”功能效果演示1、items 里面增加 search 按钮[source,|,undo,redo,|,preview,print,template,code,cut,copy,paste,plainpaste,wordpaste,|,justifyleft,justifycenter,justifyright,justifyfull,insertorderedlist,insertunorderedlis…

python excel数据可视化软件_excel是基础的数据分析与可视化工具

(原创声明&#xff0c;转载引用需要指明来源)Microsoft Excel是Microsoft为电脑编写的一款电子表格软件。直观的界面、出色的计算功能和图表工具&#xff0c;使Excel成为流行的计算机数据处理软件。管理数据Excel可以管理数据创建模板&#xff0c;使得Excel电子表格的数据自动存…

html中表单的校验的插件,功能强大的jquery.validate表单验证插件

本文实例为大家分享了jquery.validate表单验证的使用方法&#xff0c;供大家参考&#xff0c;具体内容如下1 、表单验证的准备工作在开启长篇大论之前&#xff0c;首先将表单验证的效果展示给大家。1.点击表单项&#xff0c;显示帮助提示2.鼠标离开表单项时&#xff0c;开始校验…

聊天室程序python_Python聊天室程序(基础版)

本文实例为大家分享了Python聊天室程序的具体代码&#xff0c;供大家参考&#xff0c;具体内容如下客户端代码&#xff1a;# Filename: socketClient.pyimport socketimport sysimport threading# Client GUIfrom tkinter import *import Pmw# Create a TCP/IP socketsock soc…