android 自定义ViewGroup和对view进行切图动画实现滑动菜单SlidingMenu[转]
http://blog.csdn.net/jj120522/article/details/8095852
示意图就不展示了,和上一节的一样,滑动菜单SlidingMenu效果如何大家都比较熟悉,在这里我简单说明一下用自定义ViewGroup来实现.
实现方法:我们自定义一个ViewGroup实现左右滑动,第一屏隐藏,第二屏显示.
代码如下:
- package com.jj.sliding_6;
- import android.content.Context;
- import android.util.AttributeSet;
- import android.util.Log;
- import android.view.View;
- import android.view.ViewGroup;
- import android.view.ViewTreeObserver;
- import android.view.View.MeasureSpec;
- import android.view.ViewTreeObserver.OnGlobalLayoutListener;
- import android.widget.AbsoluteLayout;
- import android.widget.LinearLayout;
- import android.widget.ListView;
- import android.widget.RelativeLayout;
- import android.widget.Scroller;
- /***
- * 自定义view
- *
- * @author zhangjia
- *
- */
- public class MyViewGroup extends ViewGroup {
- private Scroller scroller;// 滑动
- private int distance;// 滑动距离
- private View menu_view, content_view;
- private int duration = 500;
- private ViewTreeObserver viewTreeObserver;
- private Context context;
- private CloseAnimation closeAnimation;
- public static boolean isMenuOpned = false;// 菜单是否打开
- public MyViewGroup(Context context) {
- super(context, null);
- }
- public void setCloseAnimation(CloseAnimation closeAnimation) {
- this.closeAnimation = closeAnimation;
- }
- public MyViewGroup(Context context, AttributeSet attrs) {
- super(context, attrs);
- this.context = context;
- scroller = new Scroller(context);
- }
- public void setDistance(int distance) {
- this.distance = distance;
- }
- @Override
- protected void onLayout(boolean changed, int l, int t, int r, int b) {
- if (changed) {
- menu_view = getChildAt(0);// 获取滑动菜单的view
- content_view = getChildAt(1);// 获得主页view
- // 相当于fill_parent
- content_view.measure(0, 0);
- content_view.layout(0, 0, getWidth(), getHeight());
- }
- }
- @Override
- public void computeScroll() {
- Log.e("jj", "isMenuOpned=" + isMenuOpned);
- if (scroller.computeScrollOffset()) {
- scrollTo(scroller.getCurrX(), scroller.getCurrY());
- postInvalidate();// 刷新
- if (closeAnimation != null)
- closeAnimation.closeMenuAnimation();
- }else{
- MainActivity.isScrolling=false;
- }
- }
- void showMenu() {
- Log.e("jj", "shoeMenu");
- isMenuOpned = true;
- scroller.startScroll(getScrollX(), 0, -distance, 0, duration);
- invalidate();// 刷新
- }
- // 关闭菜单(执行自定义动画)
- void closeMenu() {
- Log.e("jj", "closeMenu");
- isMenuOpned = false;
- scroller.startScroll(getScrollX(), 0, distance, 0, duration);
- invalidate();// 刷新
- }
- // 关闭菜单(执行自定义动画)
- void closeMenu_1() {
- isMenuOpned = false;
- scroller.startScroll(getScrollX(), 0, distance - getWidth(), 0,
- duration);
- invalidate();// 刷新
- }
- // 关闭菜单(执行自定义动画)
- void closeMenu_2() {
- isMenuOpned = false;
- scroller.startScroll(getScrollX(), 0, getWidth(), 0, duration);
- invalidate();// 刷新
- }
- /***
- * Menu startScroll(startX, startY, dx, dy)
- *
- * dx=e1的减去e2的x,所以右移为负,左移动为正 dx为移动的距离,如果为正,则标识向左移动|dx|,如果为负,则标识向右移动|dx|
- */
- void slidingMenu() {
- Log.e("jj", "slidingMenu");
- // 没有超过半屏
- if (getScrollX() > -getWidth() / 2) {
- scroller.startScroll(getScrollX(), 0, -getScrollX(), 0, duration);
- isMenuOpned = false;
- }
- // 超过半屏
- else if (getScrollX() <= -getWidth() / 2) {
- scroller.startScroll(getScrollX(), 0, -(distance + getScrollX()),
- 0, duration);
- isMenuOpned = true;
- }
- invalidate();// 刷新
- Log.v("jj", "getScrollX()=" + getScrollX());
- }
- }
- abstract class CloseAnimation {
- // 点击list item 关闭menu动画
- public void closeMenuAnimation() {
- };
- }
上诉大部分我都加以注释,想必不用我解释太多,大家仔细看都应该可以看懂.
之后我们只需要在MainActivity中把要显示的view添加进去就可以了。
运行效果:
我把源码上传网上,大家可以下载运行,如有不足请留言.
说明一点:listview上下左右滑动冲突没有解决,不过我运行看过很多应用,要么listview不能左右滑动,要么能左右滑动但是listview不到一屏.
源码下载
下面我介绍另外一种方法,这种方法比较简单,但是有点不实用.不过对SlidingMenu滑动菜单要求不高的应用完全可以了,如:云中书城等,没有用到手势时时滑动.
实现方法:我们在点击或者滑动的时候获取当前view的切图bitmap,然后将这个bitmap传递到打开后的activity,在这个activity中布局具体如下:
- <?xml version="1.0" encoding="utf-8"?>
- <AbsoluteLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:id="@+id/layout"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent" >
- <FrameLayout
- android:id="@+id/slideout_placeholder"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:background="#777777" >
- <ListView
- android:id="@+id/list"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:cacheColorHint="#00000000" />
- </FrameLayout>
- <ImageView
- android:id="@+id/slidedout_cover"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:scaleType="fitXY" />
- </AbsoluteLayout>
这种布局目的就是让用户觉得我们操作的是一个view.
具体实现:我将代码上传网上,大家自行下载运行,有不足之处,自行调整.
效果图;
源码下载
这篇讲解比较少,不过大部分都加以注释,相信大家都看得明白.
我看了有的朋友是对HorizontalScrollView进行的自定义,实现方法比较多,因人而异,总之只要实现效果就行.
写到这里,不足的地方请之处,thanks for you .
- 上一篇:android 滑动菜单SlidingMenu的实现
- 下一篇:android listview的HeadView左右切换图片(仿新浪,网易,百度等切换图片)
转载于:https://www.cnblogs.com/fx2008/p/3262620.html
android 自定义ViewGroup和对view进行切图动画实现滑动菜单SlidingMenu[转]相关推荐
- android自定义viewgroup之我也玩瀑布流
先看效果图吧, 继上一篇<android自定义viewgroup实现等分格子布局>中实现的布局效果,这里稍微有些区别,每个格子的高度不规则,就是传说的瀑布流布局,一般实现这种效果,要么用第 ...
- android 自定义flowlayout,Android 自定义ViewGroup之实现FlowLayout-标签流容器
本篇文章讲的是Android 自定义ViewGroup之实现标签流式布局-FlowLayout,开发中我们会经常需要实现类似于热门标签等自动换行的流式布局的功能,网上也有很多这样的FlowLayout ...
- Android自定义文件路径箭头,Android自定义ViewGroup实现带箭头的圆角矩形菜单
本文和大家一起做一个带箭头的圆角矩形菜单,大概长下面这个样子: 要求顶上的箭头要对准菜单锚点,菜单项按压反色,菜单背景色和按压色可配置. 最简单的做法就是让UX给个三角形的图片往上一贴,但是转念一想这 ...
- Android自定义ViewGroup实现朋友圈九宫格控件
在我们的实际应用中,经常需要用到自定义控件,比如自定义圆形头像,自定义计步器等等,这篇文章主要给大家介绍了关于Android自定义ViewGroup实现朋友圈九宫格控件的相关资料,需要的朋友可以参考下 ...
- Android 自定义ViewGroup之实现FlowLayout-标签流容器
本篇文章讲的是Android 自定义ViewGroup之实现标签流式布局-FlowLayout,开发中我们会经常需要实现类似于热门标签等自动换行的流式布局的功能,网上也有很多这样的FlowLayout ...
- Android自定义仿Siri曲线View
Android自定义仿Siri曲线View 效果图 代码实现 仔细观察效果图可以发现,波浪其实是由4条贝塞尔曲线组成的,可以在自定义View的onDraw函数中,用Path.quadTo函数画出4条曲 ...
- android 自定义viewgroup onmeasure,Android进阶——自定义View之View的绘制流程及实现onMeasure完全攻略...
引言 Android实际项目开发中,自定义View不可或缺,而作为自定义View的一种重要实现方式--继承View重绘尤其重要,前面很多文章基本总结了继承View的基本流程:自定义属性和继承View重 ...
- android显示字符串,Android自定义View用切图显示字符串
近期开发收音机有个需求,将频率值以图片的形式显示出来(如结尾效果图所示).然而,一开始用TextView写出来的效果太丑了,提交上去肯定不合格.于是乎我想到了写一个自定义View,将频率的数字切图排布 ...
- Android自定义ViewGroup基本步骤
1.自定义属性,获取自定义属性,可参考 Android自定义View基本步骤 2.onMeasure() 方法,for循环测量子View,根据子View的宽高来计算自己的宽 高 3.onDra ...
最新文章
- Java背景颜色怎么设成随机的_JS实现随机改变背景颜色
- Design Pattern: Observer Pattern
- CCP(Cost complexity pruning) on sklearn with python implemention
- socketserver和socket的补充(验证客户端合法性)
- HDU2602 (0-1背包)
- 洛阳师范学院计算机科学与技术专业怎么样,2019洛阳师范学院专业排名
- BZOJ-1901 Zju2112 Dynamic Rankings 函数式线段树 套 树状数组+离线处理
- linux redis集群工具,Redis集群部署及常用的操作命令
- 3G技术演进策略(cdma2000,UMTS)
- 2019裁员潮,测试被裁了能干什么?
- 音创点歌机_音创ktv点歌系统
- Internet Exploer 无法打开Internet站点、、、、已终止操作
- 黑苹果2k显示器开启hidpi_关于黑苹果固态硬盘4K对齐和Trim的开启
- win7电脑无线网变身WiFi热点,让手机、笔记本共享上网
- Java环境下运行fastqc_在Ubuntu上安装FastQC
- 计算机网络开发与管理专业就业前景,计算机网络与安全管理专业就业前景和就业方向分析...
- 10个高质量免费学习网站
- 过河卒-蓝桥杯-动态规划
- APP自动化测试框架----启动APP(java)
- stm32远程报警系统的实现
热门文章
- 最新的全球编程语言,操作系统,web服务器等使用率分析报告
- Dynamo 以及一致性哈希简介
- .data和.text段合并
- C++拾趣——STL容器的插入、删除、遍历和查找操作性能对比(ubuntu g++)——插入
- C++中fstream的使用
- OpenCV 图像采样 插值 几何变换
- htc820+android+l,首款高通64位八核 HTC Desire 820评测
- linux账号管理命令,linux账号管理及相关命令和操作
- Java多线程复习:5(sleep、yield方法和线程优先级)
- Java学习总结:37(比较器)