android view显示隐藏动画效果,Android 根据手势顶部View自动展示与隐藏效果

首先来看一下效果:

c017e9fc5f2efebf21ae679ebc8d6dad.gif

大体思路如下:

总体布局用了一个自定义的ViewGroup,里面包了两个View(top View,bottomView)

我在bottomView里放了ViewPager,里面又有Fragment,Fragment里放的是ListView

原理:

ViewGroup在分发touchEvent的时候先通过手势GestureDetector判断手势方向,当向上滑动的时候让topView和bottomView同时向上移动,反之亦然。

整体思路不是很难如下是干货:

布局文件

android:id="@+id/view_group"

android:layout_width="match_parent"

android:layout_height="match_parent">

android:id="@+id/group_top"

layout="@layout/view_top" />

android:id="@+id/group_bottom"

layout="@layout/view_bottom" />

手势监听重要的是打log看一下上下滑动是数值的变化,找到其规律:

@Override

public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {

Log.i(tag, "onScroll -> distanceY" + distanceY);

if (distanceY < 0) {// 手势向下滑动是负值

animatorLayoutOffset(1);

}

if (distanceY > 0) {

animatorLayoutOffset(0f);

}

return true;

}

一定记得在ViewGroup内查找控件需要在onFinishInflate后才能找到:

@Override

protected void onFinishInflate() {

super.onFinishInflate();

viewTop = findViewById(R.id.group_top);

viewBottom = findViewById(R.id.group_bottom);

}

在ViewGroup布局的逻辑中需要处理的有一下几点:

1、onMeasure的时候要把子控件测量出来

2、onLayout时需要手动将子控件布局

接下来就是监听手势设置动画,不停的onLayout以达到topView和bottomView的布局效果

@Override

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

int width = MeasureSpec.getSize(widthMeasureSpec);

int height = MeasureSpec.getSize(heightMeasureSpec);

viewTop.measure(MeasureSpec.makeMeasureSpec(width, MeasureSpec.EXACTLY), MeasureSpec.makeMeasureSpec(height, MeasureSpec.AT_MOST));

viewBottom.measure(MeasureSpec.makeMeasureSpec(width, MeasureSpec.EXACTLY), MeasureSpec.makeMeasureSpec(height, MeasureSpec.EXACTLY));

setMeasuredDimension(width, height);

}

@Override

protected void onLayout(boolean changed, int l, int t, int r, int b) {

int topHeight = viewTop.getMeasuredHeight();

float offset = layoutOffset * topHeight;

int width = r - l;

float topViewYTop = offset - topHeight;

float topViewYBottom = topViewYTop + topHeight;

viewTop.layout(0, (int) topViewYTop, width, (int) topViewYBottom);

viewBottom.layout(0, (int) topViewYBottom, width, (int) topViewYBottom + viewBottom.getMeasuredHeight());

}

private void animatorLayoutOffset(float offset) {

if (animator != null && animator.isRunning()) {

return;

}

animator = ObjectAnimator.ofFloat(this, "layoutOffset", layoutOffset, offset);

animator.setDuration(500);

animator.start();

}

项目地址在这:

总结

以上所述是小编给大家介绍的Android 根据手势顶部View自动展示与隐藏效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

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

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

相关文章

android点击地址调用地图,Android 实现点击按钮 调用手机外部地图导航

//弹出Dialog 选择外部地图private void setMap(){final Dialog dianew AlertDialog.Builder(mContext).create();View viewLayoutInflater.from(mContext).inflate(R.layout.dialog_map, null);dia.show();dia.getWindow().setContentView(view);TextView tv_baidu(TextView) …

android webservices 返回多行多列数据,NoahWeb实现表格多行多列

用NoahWeb的表现层指令可以在动态生成的页面中非常容易的实现多行多列的表格。在正式学习以前我们需要先来了解一下怎么用NoahWeb的表现层来做动态内容显示。在NoahWeb设计器中新建或打开一项目以后&#xff0c;在Macromedia Dreamweaver MX 2004中新建了一个“空页面”&#x…

android程序 美食分享,下厨房Android产品分析

下厨房产品宣传图一、产品概况1、产品简介下厨房菜谱是一款简单实用的美食应用&#xff0c;可以帮助用户寻找想吃的美食&#xff0c;搜索精美食谱&#xff0c;使用购买清单选购食材&#xff0c;与朋友分享自己制作的美食。2、主要竞品美食杰、豆果美食、好豆菜谱、香哈菜谱。二…

html实现图片加载动画效果,HTML5+javascript实现图片加载进度动画效果

在网上找资料的时候&#xff0c;看到网上有图片加载进度的效果&#xff0c;手痒就自己也写了一个。图片加载完后&#xff0c;隐藏loading效果。想看加载效果&#xff0c;请ctrelF5强制刷新或者清理缓存。效果预览&#xff1a;0%代码如下&#xff1a;HTML5javascript实现图片加载…

html5开发app的缺点,全解HTML 5在移动Web应用的优劣势

关于HTML5HTML5具有语义学、本地存储、设备访问、连接性、多媒体、平面和三维效果、性能和集成和CSS3八大技术特征。让Web应用进入无插件时代&#xff0c;在功能和性能上逼近桌面应用。促使应用Web化&#xff0c;实现跨平台。HTML5规范草案将于2012年发布候选推荐版&#xff0c…

html怎么加断点快捷键,HTML添加断点 - osc_vyztkm1b的个人空间 - OSCHINA - 中文开源技术交流社区...

###1.前言 很多时候&#xff0c;页面的dom元素是动态添加的&#xff0c;而我们不知道具体是哪段js代码在操作这个dom元素&#xff0c;所以需要进行断点&#xff0c;对相应的dom元素进行断点监听&#xff0c;这样才能找出相关的js代码。在浏览器的调试工具中&#xff0c;切到ele…

html5 canvas 图像预览,html5-canvas 加载并显示图像

示例加载图像并将其放置在画布上var image new Image(); // 请参阅有关创建图像的注释image.src "imageURL";image.onload function(){ctx.drawImage(this,0,0);}创建图像有几种创建图像的方法new Image()document.createElement("img")作为HTML正文的…

html能插入背景的行级元素,Html元素类型:块级元素、行内元素(内联元素)和行内块级元素...

8种机械键盘轴体对比本人程序员&#xff0c;要买一个写代码的键盘&#xff0c;请问红轴和茶轴怎么选&#xff1f;html中的标签元素大体被分为三种不同的类型&#xff1a;块级元素、内联元素(又叫行内元素)和内联块级元素。事实上&#xff0c;我以前用的时候只是建立在对它们的初…

fox pro删除单条数据_Mac文件夹数据同步工具——Sync Folders Pro

Mac版同步文件夹Pro&#xff08;文件夹数据同步工具&#xff09;分享给大家&#xff01;Mac版同步文件夹Pro是一种功能强大的文件夹数据同步工具&#xff0c;可帮助您同步两一个文件夹的内容&#xff0c;包括任何子文件夹。使用文件夹同步软件&#xff0c;允许您在任一方向或两…

bp神经网络预测未来五年数据_预测 | 未来五年以太网收发器出货将达2.75亿只

新闻导读LC最新预测表明&#xff0c;从2021年到2025年间&#xff0c;供应商将售出2.75亿只以太网收发器&#xff0c;为其带来240亿美元的收入。但由于激烈的竞争、电信和企业网络投资的放缓&#xff0c;以及中美敌对升级可能导致中国云数据中心升级的延迟&#xff0c;LC下调了未…

计算机知识竞赛决赛流程,计算机知识竞赛决赛圆满结束!还不快戳?!

原标题&#xff1a;计算机知识竞赛决赛圆满结束&#xff01;还不快戳&#xff1f;&#xff01;温 馨 提 示 &#xff1a;热烈庆祝&#xff1a;青海大学 “计算机知识竞赛”圆满结束&#xff01;计算机莅临本场比赛的嘉宾有&#xff1a;计算机协会指导老师&#xff1a;贾金芳老师…

开关造成的毛刺_玻璃面板开关钻孔加工

玻璃面板开关&#xff0c;也叫做钢化玻璃开关。与传统的面板开关不同在于它是用钢化玻璃制作而成&#xff0c;但是同样能够达到控制电路的作用&#xff0c;这种开关的设计理念是为了能够达到简约时尚的作用&#xff0c;同时也具有美观与安全性&#xff0c;可以说是受到许多家庭…

html播放rtsp流,浏览器播放rtsp视频流解决方案

最近项目中需要实时播放摄像头rtsp视频流&#xff0c;于是就专门做了些研究。而浏览器不能直接播放&#xff0c;只有通过插件或者转码来实现这个需求。要实现这个目的&#xff0c;可以采用的方案非常得多&#xff0c;有商业的也有开源的&#xff0c;这里主要列举一些开源的方案…

本科计算机专业在车辆段,机电与轨道车辆工程系2021届毕业生参加成都铁路局车辆段及电务段认知实习...

2020年10月28日&#xff0c;在机电与轨道车辆工程系专业教师及辅导员们的带领下&#xff0c;轨道交通学院机电与轨道车辆工程系2017级本科车辆工程专业、机械设计制造及其自动化专业、2018级专科城市轨道交通车辆技术专业共108名学生&#xff0c;以及2017级本科电气工程专业45名…

java参数注解pam_吃透Java基础十:注解

一、什么是注解官方定义&#xff1a;注解是一系列元数据&#xff0c;它提供数据用来解释程序代码&#xff0c;但是注解并非是所解释的代码本身的一部分。注解对于代码的运行效果没有直接影响。注解有许多用处&#xff0c;主要如下&#xff1a;提供信息给编译器&#xff1a;编译…

广州计算机操作员培训,汕尾市计算机操作员报名考试时间地址及培训入口

生活习惯越来越多的计算机进入了人们的日常生活&#xff0c;随着计算机价格的逐步便宜&#xff0c;越来越多的家长为自己的孩子购置了计算机&#xff0c;但是计算机目前在我们的日常生活中&#xff0c;却没有扮演一个下面的角色&#xff0c;现在家庭中的计算机一般都是作为娱乐…

go get如何删除_Go 每日一库之 xorm

简介Go 标准库提供的数据库接口database/sql比较底层&#xff0c;使用它来操作数据库非常繁琐&#xff0c;而且容易出错。因而社区开源了不少第三方库&#xff0c;如上一篇文章中的sqlc工具&#xff0c;还有各式各样的 ORM (Object Relational Mapping&#xff0c;对象关系映射…

浮点加法器计算机组成原理,计算机组成原理 第二章运算方法与运算器

第二章运算方法与运算器运算方法&#xff1a;指算术(四则)运算和逻辑运算&#xff0c;在运算器的实现方法&#xff0c;而实现这两种运算的硬设备就是算术逻辑部件ALU(Arithmeticand Logic Unit)或称运算器由于逻辑运算及实现较简单&#xff0c;所以本章主要讨论计算机中算术四则…

wordpress添加html媒体文件,WordPress“添加媒体”文件时只显示上传到当前文章的附件图片...

最近子凡把很大一部分精力都分散在了泪雪建站的改版和泪雪网的运营中去了&#xff0c;随着泪雪网的定位和内容的新增&#xff0c;网站也需要有很多细节的升级&#xff0c;而在今天就给大家分享一个 WordPress 如何在编辑文章时“添加媒体”中默认只显示上传到本文中的附件的方法…

世界上最大的计算机硬盘,全球我最大 忆捷A600 2TB移动硬盘评测

评测工程师简介&#xff1a;PConline评测工程师&#xff1a;韩松评测工程师点评&#xff1a;移动领域里面的新霸主&#xff0c;为需要安全的人士提供了一个全新的移动理念。集安全性、技术性、容量、兼容性、稳定性、散热性等重要指标于一身。可以说忆捷A600绝对是移动硬盘领域…