近期更新了微信版本号到6.2。发现里面有个很好的体验,就是在第二个页面Activity能手势向右滑动返回,在手势滑动的过程中能看到第一个页面,这样的体验很赞,这里高仿了一下。

这里使用的是v4包里面的SlidingPaneLayout来手势滑动。在下一篇博文中将採用SlidingMenu来高仿,以下是SlidingPaneLayout高仿后的效果。效果还是蛮不错的。


最重要的是,每个页面都是Activity,而非Fragment哦,使用Activity和正常的Activity一样

这里给出demo下载地址github



以下讲一下实现的原理,里面有几个难点须要说一下

  • 手势滑动
  • 在滑动过程中看到第一个页面内容

解决方式:

  • 手势滑动借用了v4包里面的SlidingPaneLayout,由于这个SlidingPaneLayout效果和我们要实现的效果很像,所以就想着通过这个来改造,SlidingPaneLayout帮我们已经处理好了手势事件
  • 在滑动过程中看到以下的Activity页面就很easy了,仅仅要把我们当前的Activity样式设置成透明就OK了

以下一步一步来解说实现原理:

首先第一步:由于我们有的页面须要滑动返回,有的页面不须要滑动返回,所以这里抽取了一个父类BaseSwipeBackActivity,在你项目里须要加手势滑动返回的Activity。你仅仅要继承BaseSwipeBackActivity就能够了。不须要的不用继承它。

这里先看一下BaseSwipeBackActivity的源代码实现:

package com.hhl.swipebacksample;

import android.os.Bundle;
import android.support.v4.widget.SlidingPaneLayout;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.view.ViewGroup;
import android.widget.FrameLayout; import java.lang.reflect.Field; /**
* Created by hailonghan on 15/6/9.
*/
public abstract class BaseSwipeBackActivity extends AppCompatActivity implements SlidingPaneLayout.PanelSlideListener { public final static String TAG = BaseSwipeBackActivity.class.getCanonicalName(); SlidingPaneLayout mSlidingPaneLayout; FrameLayout mContainerFl; @Override
protected void onCreate(Bundle savedInstanceState) { //TODO 通过反射来改变SlidingPanelayout的值
try {
mSlidingPaneLayout = new SlidingPaneLayout(this);
//属性
Field f_overHang = SlidingPaneLayout.class.getDeclaredField("mOverhangSize");
f_overHang.setAccessible(true);
f_overHang.set(mSlidingPaneLayout, 0); mSlidingPaneLayout.setPanelSlideListener(this);
mSlidingPaneLayout.setSliderFadeColor(getResources().getColor(android.R.color.transparent));
} catch (Exception e) {
e.printStackTrace();
} super.onCreate(savedInstanceState); //加入两个view
View leftView = new View(this);
leftView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
mSlidingPaneLayout.addView(leftView, 0); mContainerFl = new FrameLayout(this);
mContainerFl.setBackgroundColor(getResources().getColor(android.R.color.white));
mContainerFl.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT)); mSlidingPaneLayout.addView(mContainerFl, 1);
} @Override
public void setContentView(int id) {
setContentView(getLayoutInflater().inflate(id, null));
} /* (non-Javadoc)
* @see android.app.Activity#setContentView(android.view.View)
*/
@Override
public void setContentView(View v) {
setContentView(v, new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
} /* (non-Javadoc)
* @see android.app.Activity#setContentView(android.view.View, android.view.ViewGroup.LayoutParams)
*/
@Override
public void setContentView(View v, ViewGroup.LayoutParams params) {
super.setContentView(mSlidingPaneLayout, params); mContainerFl.removeAllViews();
mContainerFl.addView(v, params);
} @Override
public void onPanelClosed(View view) { } @Override
public void onPanelOpened(View view) {
finish();
this.overridePendingTransition(0, R.anim.slide_out_right);
} @Override
public void onPanelSlide(View view, float v) {
}
}

看onCreate方法。这里通过java反射改动了SlidingPaneLayout的属性mOverhangSize的值,由于这个值是个私有属性,默认值是32,这个值的大小是SlidingPaneLayout左菜单离右边屏幕边缘的距离,由于我们要左菜单全屏幕大小,所以要让mOverhangSize为0,这里通过java反射来改动,代码例如以下:

//TODO 通过反射来改变SlidingPanelayout的值
try {
mSlidingPaneLayout = new SlidingPaneLayout(this);
//mOverhangSize属性,意思就是左菜单离右边屏幕边缘的距离
Field f_overHang = SlidingPaneLayout.class.getDeclaredField("mOverhangSize");
f_overHang.setAccessible(true);
//设置左菜单离右边屏幕边缘的距离为0,设置全屏
f_overHang.set(mSlidingPaneLayout, 0); mSlidingPaneLayout.setPanelSlideListener(this);
mSlidingPaneLayout.setSliderFadeColor(getResources().getColor(android.R.color.transparent));
} catch (Exception e) {
e.printStackTrace();
}

把左边菜单设置好全屏幕之后,我们给SlidingPaneLayout加两个子布局。一个是左側菜单,一个是内容显示容器布局,左側菜单布局我们要设置成透明的,由于在手势滑动的时候,我们要看究竟下的Activity页面,而内容显示布局就不应该是透明的,这里我加了白色北背景,看以下代码:


//加入两个view,这是左側菜单。由于Activity是透明的。这里就不用设置了
View leftView = new View(this);
//设置全屏
leftView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
//加入到SlidingPaneLayout中
mSlidingPaneLayout.addView(leftView, 0); //内容布局。用来存放Activity布局用的
mContainerFl = new FrameLayout(this);
//内容布局不应该是透明,这里加了白色背景 mContainerFl.setBackgroundColor(getResources().getColor(android.R.color.white));
//全屏幕显示
mContainerFl.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
//加入到SlidingPaneLayout中
mSlidingPaneLayout.addView(mContainerFl, 1);

随着手势滑动,慢慢的显示出菜单。由于整个Activity是透明的。左側菜单也是透明的,这样就能够透过左側菜单看到以下的Activity页面。当左側菜单全然打开后。我们要结束掉这个Activity,这里监听了SlidingPaneLayout的public void onPanelOpened(View view)方法。这种方法的意思就是菜单打开后运行的操作。我这里重写了这种方法。看代码例如以下:


  @Override
public void onPanelOpened(View view) {
//菜单打开后。我们结束掉这个Activity
finish();
this.overridePendingTransition(0, R.anim.slide_out_right);
}

让菜单打开后结束掉这个Activity,这样就实现了手势滑动返回上一个页面


这样我们的BaseSwipeBackActivity就写好了,那怎么来用呢。这里我们创建一个NextActivity。继承之BaseSwipeBackActivity,其它的和普通的Activity都一样,看源代码实现。事实上很easy:

package com.hhl.swipebacksample;

import android.content.Intent;
import android.graphics.Color;
import android.os.Bundle;
import android.view.View;
import android.widget.RelativeLayout; import java.util.Random;
//必须继承BaseSwipeBackActivity
public class NextActivity extends BaseSwipeBackActivity { @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//设置布局。和普通Activity一样
setContentView(R.layout.activity_next); RelativeLayout containerRl = (RelativeLayout) findViewById(R.id.container); //随机色 Random random = new Random();
int red = random.nextInt(255);
int green = random.nextInt(255);
int blue = random.nextInt(255); containerRl.setBackgroundColor(Color.argb(255,red,green,blue)); } public void nextPage(View v) {
startActivity(new Intent(this, NextActivity.class));
} }

AndroidManifest.xml声明NextActivity :

<?

xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.hhl.swipebacksample"> <application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme">
<activity
android:name=".MainActivity"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".NextActivity"
android:label="@string/title_activity_next"
android:theme="@style/JK.SwipeBack.Transparent.Theme"></activity>
</application> </manifest>

这里加入了一个主题样式@style/JK.SwipeBack.Transparent.Theme,这里要把这个Activity设置成透明样式。这样才干透过这个Activity看到以下的Activity。@style/JK.SwipeBack.Transparent.Theme源代码例如以下:

<resources xmlns:tools="http://schemas.android.com/tools">

    <!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
<!-- Customize your theme here. -->
</style> <style name="JK.SwipeBack.Transparent.Theme" parent="AppTheme">
<item name="android:windowBackground">@android:color/transparent</item>
<item name="android:windowIsTranslucent">true</item>
<item name="android:windowAnimationStyle">@style/JK.Animation.SlidingBack</item>
<item name="android:actionBarStyle">@style/JKActionBar.Custom</item>
</style> <style name="JKActionBar.Custom" parent="@style/Widget.AppCompat.Light.ActionBar.Solid.Inverse">
<item name="displayOptions">showCustom</item>
<item name="android:background">@android:color/transparent</item>
<item name="background">@android:color/transparent</item>
<item name="android:displayOptions" tools:ignore="NewApi">showCustom</item>
<item name="android:height">?actionBarSize</item>
</style> <style name="JK.Animation.SlidingBack" parent="@android:style/Animation.Activity">
<item name="android:activityOpenEnterAnimation">@anim/slide_in_right</item>
<item name="android:activityOpenExitAnimation">@anim/slide_out_right</item>
<item name="android:activityCloseEnterAnimation">@anim/slide_in_right</item>
<item name="android:activityCloseExitAnimation">@anim/slide_out_right</item>
<item name="android:wallpaperOpenEnterAnimation">@anim/slide_in_right</item>
<item name="android:wallpaperOpenExitAnimation">@anim/slide_out_right</item>
<item name="android:wallpaperCloseEnterAnimation">@anim/slide_in_right</item>
<item name="android:wallpaperCloseExitAnimation">@anim/slide_out_right</item>
<item name="android:wallpaperIntraOpenEnterAnimation">@anim/slide_in_right</item>
<item name="android:wallpaperIntraOpenExitAnimation">@anim/slide_out_right</item>
<item name="android:wallpaperIntraCloseEnterAnimation">@anim/slide_in_right</item>
<item name="android:wallpaperIntraCloseExitAnimation">@anim/slide_out_right</item>
</style> </resources>

sliding_in_right.xml源代码例如以下:

<?

xml version="1.0" encoding="utf-8"?

>
<set
xmlns:android="http://schemas.android.com/apk/res/android"
android:shareInterpolator="false"
android:zAdjustment="top">
<translate
android:duration="200"
android:fromXDelta="100.0%p"
android:toXDelta="0.0" />
</set>

sliding_out_right.xml源代码例如以下:

<?xml version="1.0" encoding="utf-8"?

>
<set
xmlns:android="http://schemas.android.com/apk/res/android"
android:shareInterpolator="false"
android:zAdjustment="top">
<translate
android:duration="200"
android:fromXDelta="0.0"
android:toXDelta="100.0%p" />
</set>

这样我们的手势滑动返回Activity就大功告成了,这里给出demo的下载地址github

Android-通过SlidingPaneLayout高仿微信6.2最新版手势滑动返回(一)的更多相关文章

  1. Android-通过SlidingMenu高仿微信6.2最新版手势滑动返回(二)

    转载请标明出处: http://blog.csdn.net/hanhailong726188/article/details/46453627 本文出自:[海龙的博客] 一.概述 在上一篇博文中,博文 ...

  2. Android -- 真正的 高仿微信 打开网页的进度条效果

    (本博客为原创,http://www.cnblogs.com/linguanh/) 目录: 一,为什么说是真正的高仿? 二,为什么要搞缓慢效果? 三,我的实现思路 四,代码,内含注释 五,使用方法与截 ...

  3. Android开发之高仿微信图片选择器

    记得刚开始做Andriod项目那会,经常会碰到一些上传图片的功能需求,特别是社交类的app,比如用户头像,说说配图,商品配图等功能都需要让我们到系统相册去选取图片,但官方却没有提供可以选取多张图片的相 ...

  4. Android高仿微信(一)——如何消除启动时的白屏

    默认情况下,APP启动时会先把屏幕刷成白色,然后才绘制第一个Activity中的View,这两个步骤之间的延迟会造成启动后先看到白屏(时间大概为1秒左右).时间不长,但是我们也看到,一般的APP时不存 ...

  5. Android 高仿微信实时聊天 基于百度云推送

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/38799363 ,本文出自:[张鸿洋的博客] 一直在仿微信界面,今天终于有幸利用百 ...

  6. Android ActionBar应用实战,高仿微信主界面的设计

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/26365683 经过前面两篇文章的学习,我想大家对ActionBar都已经有一个相对 ...

  7. Android 高仿微信头像截取 打造不一样的自定义控件

    转载请表明出处:http://blog.csdn.net/lmj623565791/article/details/39761281,本文出自:[张鸿洋的博客] 1.概述 前面已经写了关于检测手势识别 ...

  8. android高仿微信拍照、多选、预览、删除(去除相片)相冊功能

    先声明授人与鱼不如授人与渔,仅仅能提供一个思路,当然须要源代码的同学能够私下有偿问我要源代码:QQ:508181017 工作了将近三年时间了,一直没正儿八经的研究系统自带的相冊和拍照,这回来个高仿微信 ...

  9. Android 高仿微信即时聊天 百度云为基础的推

    转载请注明出处:http://blog.csdn.net/lmj623565791/article/details/38799363 ,本文出自:[张鸿洋的博客] 一直在仿微信界面,今天最终有幸利用百 ...

随机推荐

  1. creator游戏开发基本语法

    写的比较杂乱,类似随笔,随时可能往里面添加修改给lable文本赋值: this.ScoreNumber.getComponent(cc.Label).string = GAME_DATE.MMscor ...

  2. 13Microsoft SQL Server SQL 高级事务,锁,游标,分区

    Microsoft SQL Server SQL高级事务,锁,游标,分区 通过采用事务和锁机制,解决了数据库系统的并发性问题. 9.1数据库事务 (1)BEGIN TRANSACTION语句定义事务的 ...

  3. 09Microsoft SQL Server 表数据插入,更新,删除

    Microsoft SQL Server 表数据插入,更新,删除 向表中插入数据 INSERT INTO insert into tb1 values(0004,'张凤凤') insert into ...

  4. CMU-准备

    TOEFL成绩90分以上,GPA大于3.0,GRE1250分以上(不做明确要求) 申请条件:GRE成绩,建议有专科成绩;托福250,雅思7.0;简历;3封推荐信 TOEFL(The Test of E ...

  5. 【转载】Spring注解@Resource和@Autowired区别对比

    @Resource和@Autowired都是做bean的注入时使用,其实@Resource并不是Spring的注解,它的包是javax.annotation.Resource,需要导入,但是Sprin ...

  6. java求两个集合的交集和并集,比较器

    求连个集合的交集: import java.util.ArrayList; import java.util.List; public class TestCollection { public st ...

  7. MONO Design创建电信3D机房

    前面我们简单介绍了下一分钟创建3D机房,实则mono Design的功能远远不止这些,试想一下,如果我们花上10分钟来创建一个电信机房,那么MONO design又会给我们带来什么样的惊喜呢? 我们从 ...

  8. linux free命令-显示内存的使用情况

    更多Linux 性能监测与优化 关注 Linux命令大全 free命令可以显示当前系统未使用的和已使用的内存数目,还可以显示被内核使用的内存缓冲区. 语法 free(选项) 选项 -b:以Byte为单 ...

  9. buf.writeIntBE()函数详解

    buf.writeIntBE(value, offset, byteLength[, noAssert]) buf.writeIntLE(value, offset, byteLength[, noA ...

  10. https报错注销源文件内容

    open -a pycharm /Users/vivi/Library/Python/3.6/lib/python/site-packages/requests/packages/urllib3/co ...