Android slidingmenu详解 优化侧滑(1)

项目的结构层次

ExampleListActvity

|

|----------Library

|

|-------------actionbarsherlock

(三) 导包项目 与 排错


(1)导入项目后  打开 ExampleListActivity  的 properties  选择 Android 这一项

之后 可以看见缺少 /ABS  这个库    不用在意 删掉就好了   如下图    (图:1)

(2)打开library 的  properties  选择 Android 这一项

之后在library一项添加actionbar   (如图2)

(3)完成上述步骤之后会报一个错误   表示2个不同版本的    android -support- v4 .jar  冲突了

解决办法:    删除library中的    android -support- v4 .jar   或者  使用相同的 android-support-v4.jar

错误如下:

Found 2 versions of android-support-v4.jar in the dependency list,

but not all the versions are identical (check is based on SHA-1 only at this time).

All versions of the libraries must be the same at this time.

Versions found are:

Path: /Users/baozi/Documents/Dev/HuihuaWorkspace/actionbarsherlock/libs/android-support-v4.jar

Length: 271754

SHA-1: 53307dc2bd2b69fd5533458ee11885f55807de4b

Path: /Users/baozi/Documents/Dev/HuihuaWorkspace/library/libs/android-support-v4.jar

Length: 758727

SHA-1: efec67655f6db90757faa37201efcee2a9ec3507

Jar mismatch! Fix your dependencies

(4)完成上述步骤之后     library 当中还存在错误:

找不到      getSupportActionBar().setDisplayHomeAsUpEnabled( true );

解决办法:

找到Library中的src下找到SlidingFragmentActivity.java,修改父类

将:

public class SlidingFragmentActivity extends FragmentActivity

修改为:

public class SlidingFragmentActivity extends SherlockFragmentActivity

项目的结构层次

ExampleListActvity

|

|----------Library

|

|----------------actionbarsherlock

clean顺序  actionbarsherlock    、  library、 ExampleListActivity

逐个clean 项目就能运行了

(图:1)

图2:

(四) 设置详解


Simple Example :

public class SlidingExample extends Activity {

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setTitle(R.string.attach);

// set the content view

setContentView(R.layout.content);

// configure the SlidingMenu

SlidingMenu menu = new SlidingMenu(this);

menu.setMode(SlidingMenu.LEFT);

menu.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);

menu.setShadowWidthRes(R.dimen.shadow_width);

menu.setShadowDrawable(R.drawable.shadow);

menu.setBehindOffsetRes(R.dimen.slidingmenu_offset);

menu.setFadeDegree(0.35f);

menu.attachToActivity(this, SlidingMenu.SLIDING_CONTENT);

menu.setMenu(R.layout.menu);

}

}

Slidingmenu 提供属性修改

1 初始化Slidingmenu:

SlidingMenu menu = getSlidingMenu();

2 setMode //设置滑动模式

设置是左滑还是右滑,还是左右都可以滑

menu.setMode(SlidingM
enu.LEFT);//设置左滑菜单

menu.setMode(SlidingMenu.LEFT_RIGHT);//设置左右都可滑动

menu.setMode(SlidingMenu.TOUCHMODE_NONE);//不能手势滑动

3 设置SlidingMenu阴影

menu.setShadowWidthRes(R.dimen.shadow_width);//设置阴影图片的宽度

menu. setSecondaryShadowDrawable(R.drawable.shadowright);//设置右侧菜单阴影的图片资源

menu.setShadowDrawable(R.drawable.shadow);//设置左侧菜单阴影图片

4 设置SlidingMenu边框距离

menu.setBehindOffsetRes();//SlidingMenu滑出时距离边框的剩余宽度

menu.setBehindOffset(getWindowManager().getDefaultDisplay().getWidth() / 5);

// getWindowManager().getDefaultDisplay().getWidth() / 5    表示 距离屏幕宽度 1/5

5 设置SlidingMenu渐变

menu.setFadeEnabled(true);/是否有渐变

menu.setFadeDegree(0.35f);//设置渐变比率

6 设置SlidingMenu布局

sm = getSlidingMenu();

setBehindContentView(R.layout.main_menu_frame);

sm.setSecondaryMenu(R.layout.main_menu_frame_two);

messageFragment = new MessageFragment();

profileFragment = new ProfileFragment();

getSupportFragmentManager().beginTransaction().replace(R.id.menu_frame, messageFragment).commit();

getSupportFragmentManager().beginTransaction().replace(R.id.menu_frame_two, profileFragment).commit();

设置布局有3个方法  :

setContentView(R.layout.main);  //设置slidingmenu中间的布局

setBehindContentView(R.layout.main_menu_frame);//设置左侧的布局

sm.setSecondaryMenu(R.layout.main_menu_frame_two);//设置右侧的布局

使用的是左右两侧 我一般设置为 fragment

getSupportFragmentManager().beginTransaction().replace(R.id.menu_frame,messageFragment).commit();

表示为替换 fragment

7 设置SlidingMenu滑动的拖拽效果

slidingMenu.setBehindScrollScale(0);

8 设置SlidingMenu判断打开状态 并 自动关闭或开启

menu.toggle();

如果SlidingMenu 它是open的,它会被关闭,反之亦然。

9 设置SlidingMenu触碰屏幕的范围

menu.setTouchModeBehind(SlidingMenu.TOUCHMODE_FULLSCREEN);

menu.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);

设置菜单滑动,触碰屏幕的范围setTouchModeAbove

10 设置SlidingMenu关闭器监听

监听主要分2种   open  和  close

open:

menu.setOnOpenedListener(onOpenListener);//监听slidingmenu打开之后调用

menu.setOnOpenListener(onOpenListener);//监听slidingmenu打开时调用

close:

两个监听器  注意看了   一个是  closed  一个是 close

menu.setOnClosedListener(listener);

menu.setOnCloseListener(listener);

这两个的区别就是

menu.OnCloseListener(OnClosedListener);//监听Slidingmenu关闭时事件

menu.OnClosedListener(OnClosedListener);//监听Slidingmenu关闭后事件

11 设置SlidingMenu是否淡入/淡出

menu.setFadeEnabled(true);

12 其它

menu.showMenu();//显示SlidingMenu

menu.showContent();//显示内容

menu.attachToActivity(this, SlidingMenu.SLIDING_CONTENT);//使SlidingMenu附加在Activity上

menu.setMenu(R.layout.menu);//设置menu的布局文件

等等

  • 19
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值