转载请注明出处:http://blog.csdn.net/zhaokaiqiang1992

在非常久之前的一篇文章中,简单的介绍了一下开源项目SlidingMenu控件的使用,这一篇文章,将比較具体的介绍最新版本号的SlidingMenu控件的用法。

SlidingMenu的github地址:https://github.com/jfeinstein10/SlidingMenu

将SlidingMenu整合到自己的项目之中

我们在使用开源的项目之前,都须要先将项目作为资源引入到我们当前的项目之中。在整合之前,先将github上项目的演示样例代码下载下来。导入到eclipse其中。关于将外部项目导入当前项目。有两种做法。

(1)将资源项目作为library设置到我们的项目中,就像是演示样例代码中的ExampleListctivity一样,例如以下图所看到的。

有一点须要注意一下。由于在SlidingMenu演示样例代码里面用到了ActionBarSharlock这个依赖project。因此,我们不光须要SlidingMenu的代码。还须要ActionBarSharlockproject的资源项目。ActionBarSharlock的github项目地址是https://github.com/JakeWharton/ActionBarSherlock 大家能够自行下载。

在设置好依赖project之后,我们就能够使用SlidingMenu了。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvemhhb2thaXFpYW5nMTk5Mg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

(2)除了採用上面这样的依赖project的方法,我们还能够直接将依赖project,也就是library项目里面的代码,直接复制到我们的目标项目里面。我个人更喜欢这样的方法,尽管这样会添加project的安装包的体积,可是。对于项目的管理来说,更加的方便。

在这个项目中。我们将以下的这个文件复制到我们的项目里面就能够了。

加入SlidingMenu控件的方式

(1)继承自SlidingFragmentActivity。假设是採用这样的方式的话。我们的Activity须要继承自SlidingFragmentActivity。SlidingFragmentActivity是SlidingMenu里面的一个类。继承自它,我们能够拥有一个SlidingMenu控件。

假设我们想用这个方式,能够參考以下的代码。

package com.example.slidingmenudemo;

import android.os.Bundle;
import android.support.v4.app.FragmentTransaction; import com.jeremyfeinstein.slidingmenu.lib.SlidingMenu;
import com.jeremyfeinstein.slidingmenu.lib.app.SlidingFragmentActivity; /**
* 继承自SlidingFragmentActivity的側滑栏实现,能够实现側滑栏是fragment的側滑栏的效果
*
* @author zhaokaiqiang
* @see http://blog.csdn.net/zhaokaiqiang1992
*
*/
public class MethodOneActivity extends SlidingFragmentActivity { @Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// 设置主界面的布局文件
setContentView(R.layout.activity_method_one);
// 设置存放側滑栏的容器的布局文件
setBehindContentView(R.layout.frame_menu);
// 将側滑栏的fragment类填充到側滑栏的容器的布局文件里
FragmentTransaction transaction = getSupportFragmentManager()
.beginTransaction();
SampleListFragment fragment = new SampleListFragment();
transaction.replace(R.id.menu_frame, fragment);
transaction.commit();
// 获取到SlidingMenu对象。然后设置一些常见的属性
SlidingMenu sm = getSlidingMenu();
// 设置阴影的宽度
sm.setShadowWidth(0);
// 设置阴影的颜色
sm.setShadowDrawable(R.drawable.shadow);
// 设置側滑栏全然展开之后。距离另外一边的距离,单位px,设置的越大,側滑栏的宽度越小
sm.setBehindOffset(100);
// 设置渐变的程度。范围是0-1.0f,设置的越大。则在側滑栏刚划出的时候。颜色就越暗。1.0f的时候,颜色为全黑
sm.setFadeDegree(0.3f);
// 设置触摸模式。能够选择全屏划出,或者是边缘划出。或者是不可划出
sm.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN); //设置actionBar是否能尾随側滑栏移动,假设没有,则能够去掉
setSlidingActionBarEnabled(false); }
}

使用这样的实现方式。我们的側滑栏是使用一个Fragment实现的。通过setBehindContentView()方法,我们能够设置放置側滑栏布局的容器。这个容器是一个很easy的布局文件,一般来说比較固定,比方像以下这样就能够

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

>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/menu_frame"
android:layout_width="match_parent"
android:layout_height="match_parent" />

在这里面,一个设置了id的FragmentLayout布局就可以。这样我们就能够通过transaction.replace(R.id.menu_frame, fragment);方法将我们側滑栏的Fragment填充到SlidingMenu之中。

由于SlidingFragmentActivity里面已经集成了一个SlidingMenu。因此。我们通过getSlidingMenu()就能够获取到一个SilidingMenu对象,然后象上面的代码一样设置经常使用的属性就能够了。

通过这样的方式加入SlidingMenu很的方便,可是我们必须继承自SlidingFeagmentActivity,不免有一些限制。

(2)继承自FragmentActivity

除了继承SlidingMenu自带的Activity之外,我们还能够直接继承自FragmentActivity,假设要通过这样的方式。我们能够參考以下的代码实现。

package com.example.slidingmenudemo;

import android.os.Bundle;
import android.support.v4.app.FragmentActivity; import com.jeremyfeinstein.slidingmenu.lib.SlidingMenu; /**
* 继承自FragmentActivity的側滑栏实现,能够实现側滑栏是fragment的側滑栏的效果
*
* @author zhaokaiqiang
* @see http://blog.csdn.net/zhaokaiqiang1992
*/
public class MethodTwoActivity extends FragmentActivity { private SlidingMenu menu; @Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_method_two); menu = new SlidingMenu(this);
menu.setShadowWidth(0);
menu.setShadowDrawable(R.drawable.shadow);
menu.setBehindOffset(100);
menu.setFadeDegree(0.35f);
menu.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);
menu.attachToActivity(this, SlidingMenu.SLIDING_CONTENT);
menu.setMenu(R.layout.frame_menu);
getSupportFragmentManager().beginTransaction()
.replace(R.id.menu_frame, new SampleListFragment()).commit(); }
}

通过这样的方式集成的话,我们须要自定义SlidingMenu。然后通过attachToActivity。将SlidingMenu连接到我们的FragmentActivity之上,setMenu()方式设置的是我们的側滑栏的容器的布局。和上面的第一种方法是一样的。

其它经常使用属性

(1)双側滑栏
    我们能够通过以下的代码实现双側滑栏的效果
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//设置左边的側滑栏
getSlidingMenu().setMode(SlidingMenu.LEFT_RIGHT);
getSlidingMenu().setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);
setContentView(R.layout.content_frame);
getSupportFragmentManager().beginTransaction()
.replace(R.id.content_frame, new SampleListFragment()).commit();
//设置右边的側滑栏
getSlidingMenu().setSecondaryMenu(R.layout.menu_frame_two);
getSlidingMenu().setSecondaryShadowDrawable(R.drawable.shadowright);
getSupportFragmentManager().beginTransaction()
.replace(R.id.menu_frame_two, new SampleListFragment())
.commit();
}

(2)设置触摸模式

通过getSlidingMenu().setTouchModeAbove()能够设置側滑栏的触摸模式,用以下3个常量值

SlidingMenu.TOUCHMODE_FULLSCREEN  全屏幕模式。全屏滑动都可打开

SlidingMenu.TOUCHMODE_MARGIN  側边模式,仅仅在屏幕側边滑动才干打开,中心滑动不能打开

SlidingMenu.TOUCHMODE_NONE    禁止触摸模式,不可以通过触摸打开。仅仅可以通过SlidingMenu().toggle()打开或者是关闭

(3)设置側滑栏显示动画

通过SlidingMenu.setBehindCanvasTransformer(CanvasTransformer);方法能够设置側滑栏的显示动画,參数是一个CanvasTransformer对象。以下是几个常见的动画的设置

折叠动画
new CanvasTransformer() {
@Override
public void transformCanvas(Canvas canvas, float percentOpen) {
canvas.scale(percentOpen, 1, 0, 0);
}
}

放缩动画

new CanvasTransformer() {
@Override
public void transformCanvas(Canvas canvas, float percentOpen) {
float scale = (float) (percentOpen*0.25 + 0.75);
canvas.scale(scale, scale, canvas.getWidth()/2, canvas.getHeight()/2);
}
}

上升动画

private static Interpolator interp = new Interpolator() {
@Override
public float getInterpolation(float t) {
t -= 1.0f;
return t * t * t + 1.0f;
}
}; new CanvasTransformer() {
@Override
public void transformCanvas(Canvas canvas, float percentOpen) {
canvas.translate(0, canvas.getHeight()*(1-interp.getInterpolation(percentOpen)));
}
}

其它的很多其它属性。请自己查阅演示样例代码。


【Android界面实现】SlidingMenu最新版本号使用具体解释的更多相关文章

  1. 【FastDev4Android框架开发】打造QQ6.X最新版本号側滑界面效果(三十八)

    转载请标明出处: http://blog.csdn.net/developer_jiangqq/article/details/50253925 本文出自:[江清清的博客] (一).前言: [好消息] ...

  2. Android应用之——最新版本号SDK V2.4实现QQ第三方登录

    为什么要写这篇博客呢?由于.我在做这个第三方登录的时候,找了非常多资料,发现要么就是过时了.要么就是说的非常不清楚.非常罗嗦.并且非常多都是一些小demo,不是什么实例.甚至连腾讯官方的文档都有这个问 ...

  3. Win7环境下VS2010配置Cocos2d-x-2.1.4最新版本号的开发环境

    写这篇博客时2D游戏引擎Cocos2d-x的最新版本号为2.1.4,记得非常久曾经使用博客园博主子龙山人的一篇博文<Cocos2d-x win7+vs2010配置图文具体解释(亲測)>成功 ...

  4. Android自己主动检測版本号及自己主动升级

    步骤: 1.检測当前版本号的信息AndroidManifest.xml-->manifest-->android:versionName. 2.从server获取版本号号(版本号号存在于x ...

  5. CSipSimple最新版本号(二)--加入视频功能

    前面我们编译好了最新版本号的CSipSimple,并且測试已经能够打电话了.如今要把视频功能加上去. 不知道怎么编译的,能够看我的上一篇博文:CSipSimple最新版本号 我们先来看一下之前的项目是 ...

  6. Mac下改动Android Studio 所用的JDK版本号

    Mac下改动Android Studio 所用的JDK版本号 @author ASCE1885 近期项目从Eclipse+Ant构建模式转移到了Android Studio+Gradle构建模式.自然 ...

  7. 【Android界面实现】Drawable Animation 使用介绍

        转载请注明出处:http://blog.csdn.net/zhaokaiqiang1992     (眼下仅仅能用在View对象上的动画效果的实现有两种,一种就是上一篇的View Animat ...

  8. Android 6.0及以上版本号的执行时权限介绍

    执行时权限(Runtime Permission)是Android 6.0( 代号为 Marshmallow,API版本号为 23)及以上版本号新增的功能.相比于以往版本号,这是一个较大变化. 本文将 ...

  9. 最新版本号cocos2d&#173;2.0&#173;x&#173;2.0.2使用新资源载入策略!不再沿用-hd、-

     前段时间cocos2dx更新了最新版本号cocos2d­2.0­x­2.0.2.也从这个版本号開始对于资源载入与管理都改变了策略. 在之前的载入方式都是通过沿用与cocos2d-iphone一样 ...

随机推荐

  1. Java项目打包发布

    Java项目打包发布 如果只想发布为一个可执行的jar包,使用eclipse的Export功能就可以了 使用eclipse的Export功能,将项目中的所有package打包为一个pet.jar文件, ...

  2. 洛谷P1040 加分二叉树(区间dp)

    P1040 加分二叉树 题目描述 设一个n个节点的二叉树tree的中序遍历为(1,2,3,…,n),其中数字1,2,3,…,n为节点编号.每个节点都有一个分数(均为正整数),记第i个节点的分数为di, ...

  3. bzoj3687简单题(dp+bitset优化)

    3687: 简单题 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 861  Solved: 399[Submit][Status][Discuss] ...

  4. Python 38 注册和修改密码

    一:注册系统服务 1.添加环境变量:桌面点击我的电脑------>右键属性------>双击高级系统设置------>点击环境变量------>找到在系统变量中的Path后双击 ...

  5. 前端常见面试题总结part2

    今天总结了几道,感觉非常有意思的题,有感兴趣的可以看下,有疑问请留言~ (答案在最后) 考察自执行函数的this指向 审题要细心 var n = 2, obj = { n:2, fn:(functio ...

  6. 【LOJ#10115,tyvj1473】校门外的树(第3次升级)

    PS:思路来源于Clove_unique的博客,在此万分感谢 这道题可以用树状数组轻松过,然而...树状数组不太熟悉,还是用线段树比较好(虽然代码比较长) [思路分析] [一开始的思路] 最开始的错误 ...

  7. [转载]cocos2d-触摸分发原理

    本文由泰然翻译组组长 TXX_糖炒小虾 原创,版权所有,转载请注明出处并通知作者和泰然! 原作 http://www.ityran.com/archives/1326/comment-page-1 触 ...

  8. Go中的main函数和init函数

    Go里面有两个保留的函数:init函数(能够应用于所有的package)和main函数(只能应用于package main).这两个函数在定义时不能有任何的参数和返回值.虽然一个package里面可以 ...

  9. 如何用js代码实现图片切换效果

    通过点击按钮,实现图片的隐藏与显现,切换. 实现代码:<style> .a{ width: 300px; height: 300px; border: 1px solid black; } ...

  10. C++版的LLC代码

    图像稀疏编码总结:LLC和SCSPM,文章对稀疏编码讲解非常详细. <Locality-constrained Linear Coding for Image Classification> ...