slidingmenu开源效果

本文将更进一步, 在很多实际的应用场景中我们需要一个更复杂的场景,比如说需要在一个菜单选项中集成多个tab来集中显示信息。这个时候 Viewpager就派上用场了。

本例中我们将通过SlidingMenu + ViewPager+Fragment 实现带TAB的SlidingMenu。先看看具体的效果。

实现步骤跟上一篇大体相同,这里着重说需要修改的地方

首先我们需要添加一个PagerAdapter来自动适配Tab里面的Fragment ,就像ListView中的BaseAdapter差不多,只是需要实现的方法有一些区别。

[java] view plaincopy

  1. package com.example.slidingmenuviewpagertest.adapter;  
  2.   
  3. import java.util.List;  
  4.   
  5. import com.example.slidingmenuviewpagertest.entity.ContentBean;  
  6. import com.example.slidingmenuviewpagertest.fragment.TestContentFragment;  
  7.   
  8. import android.support.v4.app.Fragment;  
  9. import android.support.v4.app.FragmentManager;  
  10. import android.support.v4.app.FragmentPagerAdapter;  
  11.   
  12. public class ContentFragmentPagerAdapter extends FragmentPagerAdapter {  
  13.   
  14.     private List<ContentBean> list;  
  15.     public ContentFragmentPagerAdapter(FragmentManager fm) {  
  16.         super(fm);  
  17.     }  
  18.       
  19.     public ContentFragmentPagerAdapter(FragmentManager fm,List<ContentBean> list) {  
  20.         super(fm);  
  21.         this.list = list;  
  22.     }  
  23.   
  24.     @Override  
  25.     public Fragment getItem(int arg0) {  
  26.           
  27.         return TestContentFragment.newInstance(list.get(arg0).getContent());  
  28.           
  29.     }  
  30.   
  31.     @Override  
  32.     public int getCount() {  
  33.         // TODO Auto-generated method stub  
  34.         return list.size();  
  35.     }  
  36.       
  37.     @Override  
  38.     public CharSequence getPageTitle(int position) {  
  39.         // TODO Auto-generated method stub  
  40.         return list.get(position).getTitle();  
  41.     }  
  42.   
  43. }  

然后在首页Fragment 中初始化ViewPager

[java] view plaincopy

  1. package com.example.slidingmenuviewpagertest.fragment;  
  2.   
  3. import java.util.ArrayList;  
  4. import java.util.List;  
  5.   
  6. import android.os.Bundle;  
  7. import android.support.v4.app.Fragment;  
  8. import android.support.v4.view.ViewPager;  
  9. import android.view.LayoutInflater;  
  10. import android.view.View;  
  11. import android.view.ViewGroup;  
  12.   
  13. import com.example.slidingmenuviewpagertest.R;  
  14. import com.example.slidingmenuviewpagertest.adapter.ContentFragmentPagerAdapter;  
  15. import com.example.slidingmenuviewpagertest.entity.ContentBean;  
  16.   
  17. public class HomeFragment extends Fragment {  
  18.       
  19.     private ViewPager mViewPager;  
  20.     private static final String[] titles = {"One","Two","Three","Four","Five"};  
  21.     private List<ContentBean> list = new ArrayList<ContentBean>();  
  22.     private ContentFragmentPagerAdapter mAdapter;  
  23.       
  24.     public HomeFragment(){}  
  25.       
  26.     @Override  
  27.     public View onCreateView(LayoutInflater inflater, ViewGroup container,  
  28.             Bundle savedInstanceState) {  
  29.    
  30.         View rootView = inflater.inflate(R.layout.fragment_home, container, false);  
  31.           
  32.         initData();  
  33.         findView(rootView);  
  34.           
  35.         return rootView;  
  36.     }  
  37.   
  38.     private void initData() {  
  39.           
  40.         for(int i=0;i<titles.length;i++){  
  41.               
  42.             ContentBean cb = new ContentBean();  
  43.             cb.setTitle(titles[i]);  
  44.             cb.setContent(titles[i]+"_"+(i+1));  
  45.               
  46.             list.add(cb);  
  47.         }  
  48.     }  
  49.   
  50.     private void findView(View rootView) {  
  51.           
  52.         mViewPager = (ViewPager) rootView.findViewById(R.id.mViewPager);  
  53.         mAdapter = new ContentFragmentPagerAdapter(getActivity().getSupportFragmentManager(),list);  
  54.         mViewPager.setAdapter(mAdapter);  
  55.     }  
  56.       
  57.     @Override  
  58.     public void onStart() {  
  59.           
  60.         if(mAdapter!=null){  
  61.             mAdapter.notifyDataSetChanged();  
  62.         }  
  63.           
  64.         super.onStart();  
  65.     }  
  66. }  

ViewPager中的Fragment

[java] view plaincopy

  1. package com.example.slidingmenuviewpagertest.fragment;  
  2.   
  3. import android.os.Bundle;  
  4. import android.support.v4.app.Fragment;  
  5. import android.util.Log;  
  6. import android.view.LayoutInflater;  
  7. import android.view.View;  
  8. import android.view.ViewGroup;  
  9. import android.widget.TextView;  
  10.   
  11. import com.example.slidingmenuviewpagertest.R;  
  12.   
  13. public class TestContentFragment extends Fragment {  
  14.     private static final String TAG = TestContentFragment.class.getSimpleName();  
  15.     private String title = "Hello";  
  16.       
  17.     public static TestContentFragment newInstance(String s) {  
  18.         TestContentFragment newFragment = new TestContentFragment();  
  19.         Bundle bundle = new Bundle();  
  20.         bundle.putString("title", s);  
  21.         newFragment.setArguments(bundle);  
  22.           
  23.         return newFragment;  
  24.   
  25.     }  
  26.       
  27.     @Override  
  28.     public void onCreate(Bundle savedInstanceState) {  
  29.           
  30.         Log.d(TAG, "TestContentFragment-----onCreate");  
  31.         Bundle args = getArguments();  
  32.         if(args!=null){  
  33.             title = args.getString("title");  
  34.         }  
  35.           
  36.         super.onCreate(savedInstanceState);  
  37.     }  
  38.       
  39.     @Override  
  40.     public View onCreateView(LayoutInflater inflater, ViewGroup container,  
  41.             Bundle savedInstanceState) {  
  42.           
  43.          View rootView = inflater.inflate(R.layout.fragment_test_content, container, false);  
  44.            
  45.          findView(rootView);  
  46.            
  47.          return rootView;  
  48.     }  
  49.   
  50.     private void findView(View rootView) {  
  51.           
  52.         TextView txtLabel = (TextView) rootView.findViewById(R.id.txtLabel);  
  53.         txtLabel.setText(title);  
  54.     }  
  55. }  

TestContentFragment 布局文件 fragment_test_content.xml

[html] view plaincopy

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent" >  
  5.   
  6.     <TextView  
  7.         android:id="@+id/txtLabel"  
  8.         android:layout_width="wrap_content"  
  9.         android:layout_height="wrap_content"  
  10.         android:layout_centerInParent="true"  
  11.         android:text="Pages View"  
  12.         android:textSize="16dp" />  
  13.   
  14.     <ImageView  
  15.         android:layout_width="wrap_content"  
  16.         android:layout_height="wrap_content"  
  17.         android:layout_below="@id/txtLabel"  
  18.         android:layout_centerHorizontal="true"  
  19.         android:layout_marginTop="10dp"  
  20.         android:src="@drawable/ic_launcher" />  
  21.   
  22. </RelativeLayout>  

首页Fragment 布局文件 fragment_home.xml

[html] view plaincopy

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent" >  
  5.   
  6.     <android.support.v4.view.ViewPager  
  7.         android:id="@+id/mViewPager"  
  8.         android:layout_width="match_parent"  
  9.         android:layout_height="wrap_content" >  
  10.           
  11.         <android.support.v4.view.PagerTabStrip      
  12.             android:id="@+id/pagertab"      
  13.             android:layout_width="wrap_content"      
  14.             android:layout_height="wrap_content"      
  15.             android:layout_gravity="top"/>      
  16.           
  17. <!--         <android.support.v4.view.PagerTitleStrip  
  18.             android:id="@+id/mPagerTitleStrip"  
  19.             android:layout_width="match_parent"  
  20.             android:layout_height="wrap_content"  
  21.             android:layout_gravity="top" /> -->  
  22.     </android.support.v4.view.ViewPager>  
  23.   
  24. </RelativeLayout>  

主Activity跟之前没有变化

[java] view plaincopy

  1. package com.example.slidingmenuviewpagertest;  
  2.   
  3. import android.annotation.SuppressLint;  
  4. import android.os.Bundle;  
  5. import android.support.v4.app.Fragment;  
  6. import android.support.v4.app.FragmentManager;  
  7. import android.support.v4.app.FragmentTransaction;  
  8. import android.util.Log;  
  9. import android.view.Menu;  
  10. import android.view.MenuItem;  
  11. import com.example.slidingmenuviewpagertest.fragment.CommunityFragment;  
  12. import com.example.slidingmenuviewpagertest.fragment.FindPeopleFragment;  
  13. import com.example.slidingmenuviewpagertest.fragment.HomeFragment;  
  14. import com.example.slidingmenuviewpagertest.fragment.MenuFragment;  
  15. import com.example.slidingmenuviewpagertest.fragment.MenuFragment.SLMenuListOnItemClickListener;  
  16. import com.example.slidingmenuviewpagertest.fragment.PagesFragment;  
  17. import com.example.slidingmenuviewpagertest.fragment.PhotosFragment;  
  18. import com.example.slidingmenuviewpagertest.fragment.WhatsHotFragment;  
  19. import com.jeremyfeinstein.slidingmenu.lib.SlidingMenu;  
  20. import com.jeremyfeinstein.slidingmenu.lib.app.SlidingFragmentActivity;  
  21.   
  22. public class MainActivity extends SlidingFragmentActivity implements SLMenuListOnItemClickListener{  
  23.       
  24.     private SlidingMenu mSlidingMenu;  
  25.       
  26.     @SuppressLint("NewApi")  
  27.     @Override  
  28.     public void onCreate(Bundle savedInstanceState) {  
  29.         super.onCreate(savedInstanceState);  
  30.           
  31.         setTitle("Home");  
  32. //      setTitle(R.string.sliding_title);  
  33.         setContentView(R.layout.frame_content);  
  34.   
  35.         //set the Behind View  
  36.         setBehindContentView(R.layout.frame_menu);  
  37.           
  38.         // customize the SlidingMenu  
  39.         mSlidingMenu = getSlidingMenu();  
  40. //      mSlidingMenu.setSecondaryMenu(R.layout.frame_menu); 设置右侧菜单的布局文件  
  41.           
  42. //      mSlidingMenu.setShadowWidth(5);  
  43. //      mSlidingMenu.setBehindOffset(100);  
  44.         mSlidingMenu.setShadowDrawable(R.drawable.drawer_shadow);//设置阴影图片  
  45.         mSlidingMenu.setShadowWidthRes(R.dimen.shadow_width); //设置阴影图片的宽度  
  46.         mSlidingMenu.setBehindOffsetRes(R.dimen.slidingmenu_offset); //SlidingMenu划出时主页面显示的剩余宽度  
  47.         mSlidingMenu.setFadeDegree(0.35f);  
  48.         //设置SlidingMenu 的手势模式  
  49.         //TOUCHMODE_FULLSCREEN 全屏模式,在整个content页面中,滑动,可以打开SlidingMenu  
  50.         //TOUCHMODE_MARGIN 边缘模式,在content页面中,如果想打开SlidingMenu,你需要在屏幕边缘滑动才可以打开SlidingMenu  
  51.         //TOUCHMODE_NONE 不能通过手势打开SlidingMenu  
  52.         mSlidingMenu.setTouchModeAbove(SlidingMenu.TOUCHMODE_MARGIN);  
  53.   
  54.         //设置 SlidingMenu 内容  
  55.         FragmentTransaction fragmentTransaction = getSupportFragmentManager().beginTransaction();  
  56.         MenuFragment menuFragment = new MenuFragment();  
  57.         fragmentTransaction.replace(R.id.menu, menuFragment);  
  58.         fragmentTransaction.replace(R.id.content, new HomeFragment());  
  59.         fragmentTransaction.commit();  
  60.           
  61.         //使用左上方icon可点,这样在onOptionsItemSelected里面才可以监听到R.id.home  
  62.         getActionBar().setDisplayHomeAsUpEnabled(true);  
  63.     }  
  64.   
  65.     @Override  
  66.     public boolean onCreateOptionsMenu(Menu menu) {  
  67.         // Inflate the menu; this adds items to the action bar if it is present.  
  68.         getMenuInflater().inflate(R.menu.main, menu);  
  69.         return true;  
  70.     }  
  71.       
  72.     @Override  
  73.     public boolean onOptionsItemSelected(MenuItem item) {  
  74.         switch (item.getItemId()) {  
  75.         case android.R.id.home:  
  76.               
  77.             toggle(); //动态判断自动关闭或开启SlidingMenu  
  78. //          getSlidingMenu().showMenu();//显示SlidingMenu  
  79. //          getSlidingMenu().showContent();//显示内容  
  80.             return true;  
  81.         }  
  82.         return super.onOptionsItemSelected(item);  
  83.     }  
  84.   
  85.     @SuppressLint("NewApi")  
  86.     @Override  
  87.     public void selectItem(int position, String title) {  
  88.         // update the main content by replacing fragments    
  89.         Fragment fragment = null;    
  90.         switch (position) {    
  91.         case 0:    
  92.             fragment = new HomeFragment();    
  93.             break;    
  94.         case 1:    
  95.             fragment = new FindPeopleFragment();    
  96.             break;    
  97.         case 2:    
  98.             fragment = new PhotosFragment();    
  99.             break;    
  100.         case 3:    
  101.             fragment = new CommunityFragment();    
  102.             break;    
  103.         case 4:    
  104.             fragment = new PagesFragment();    
  105.             break;    
  106.         case 5:    
  107.             fragment = new WhatsHotFragment();    
  108.             break;    
  109.         default:    
  110.             break;    
  111.         }    
  112.         
  113.         if (fragment != null) {    
  114.             FragmentManager fragmentManager = getSupportFragmentManager();  
  115.             fragmentManager.beginTransaction()    
  116.                     .replace(R.id.content, fragment).commit();    
  117.             // update selected item and title, then close the drawer    
  118.             setTitle(title);  
  119.             mSlidingMenu.showContent();  
  120.         } else {    
  121.             // error in creating fragment    
  122.             Log.e("MainActivity", "Error in creating fragment");    
  123.         }    
  124.     }  
  125. }  

Demo下载地址:http://download.csdn.net/detail/fx_sky/6723771

时间: 2024-12-30 21:36:34

slidingmenu开源效果的相关文章

安卓UI设计与开发教程 滑动菜单栏(三)SlidingMenu动画效果的实现

经过上一篇文章的学习,相信大家对开源项目SlidingMenu的用法已经有了一个非常深入的了解,那么这一 章博主就来教大家滑动菜单栏滑动时动画效果的实现.博主这里用了三个不同动画效果的基础示例来教大家如 何去实现,等大家弄懂了之后完全可以做到举一反三,去实现更多不同的动画效果,让你的应用软件给用户带 来眼前一亮的效果. 一.SlidingMenu动画效果示例一 1.示例一效果图 该示例实现了 滑动时缩放的效果,看左边的效果图可以明显的感觉到,滑动菜单栏刚刚打开时的图片比右边的效果图滑动菜 单栏打

AJAX开源效果网址

* 风琴效果(Accordion)http://www.hellocto.com/wz/list.aspx?cid=241* 自动完成(AutoComplete)http://www.hellocto.com/wz/list.aspx?cid=242* 动画(Animation)http://www.hellocto.com/wz/list.aspx?cid=243* 日期(Calendar)http://www.hellocto.com/wz/list.aspx?cid=244* 图表(Cha

安卓UI设计与开发教程 滑动菜单栏(二)开源项目SlidingMenu的示例

通过上一篇文章的讲解,相信大家对于开源项目SlidingMenu都有了一个比较初步的了解(不了解的可以参 考上一篇文章),那么从这一章开始,博主将会以SlidingMenu为重心,给大家带来非常丰富的示例演示,让 大家对SlidingMenu有一个更加深入的了解以及如何去实现一些比较炫的滑动效果. 这篇文章会给大家 带来7个不同效果的示例,每个示例都包含了最基本的使用方法,从易到难,循序渐进.能够让初学者可以快 速的掌握SlidingMenu的使用方法.下一篇文章会给大家带来三种不同的动画效果来

安卓UI设计与开发教程 滑动菜单栏(一)开源项目SlidingMenu的使用

由于最近的工作确实比较忙的原因,所以这个系列的教程有一段时间没有更新了,也请各位读者见谅. 这期博主要给大家带来的是关于滑动菜单栏的实现效果. 一.SlidingMenu简介 相信大家对SlidingMenu都不陌生了,它是一种比较新的设置界面或配置界面的效果,在主界面左滑或者右滑出现设置界面效果,能方便的进行各种操作.很多优秀的应用都采用了这种界面方案,像facebook.人人网.everynote.Google+等等.如下图所示: Google+界面效果图 开发教程 滑动菜单栏(一)开源项目

Android 开源项目侧边栏菜单(SlidingMenu)使用详解_Android

项目下载地址:https://github.com/jfeinstein10/SlidingMenu 注意: SlidingMenu依赖于另一个开源项目ActionBarSherlock,所以需要将ActionBarSherlock添加作为SlidingMenu的库工程,否则会报资源找不到错误. 然后再将SlidingMenu添加到自己的工程中去. SlidingMenu集成常见错误: Jar mismatch! Fix your dependencies :引用的工程和自身工程以来的jar包版

Android UI实现SlidingMenu侧滑菜单效果_Android

本篇博客给大家分享一个效果比较好的侧滑菜单的Demo,实现点击左边菜单切换Fragment. 效果如下:   主Activity代码: package com.infzm.slidingmenu.demo; import android.os.Bundle; import android.support.v4.app.Fragment; import android.view.View; import android.view.View.OnClickListener; import andro

Android SlidingMenu 仿网易新闻客户端布局

前面两篇文章中的SlidingMenu都出现在左侧,今天来模仿一下网易新闻客户端左右两边都有SlidingMenu的效果,以下是网易新闻客户端效果:               不扯闲话了,直接进入正题吧   frame_content.xml   [html] view plaincopy   <?xml version="1.0" encoding="utf-8"?>   <FrameLayout xmlns:android="htt

Android自定义ViewGroup打造各种风格的SlidingMenu

上篇给大家介绍QQ5.0侧滑菜单的视频课程,对于侧滑的时的动画效果的实现有了新的认识,似乎打通了任督二脉,目前可以实现任意效果的侧滑菜单了,感谢鸿洋大大!! 用的是HorizontalScrollView来实现的侧滑菜单功能,HorizontalScrollView的好处是为我们解决了滑动功能,处理了滑动冲突问题,让我们使用起来非常方便,但是滑动和冲突处理都是android中的难点,是我们应该掌握的知识点,掌握了这些,我们可以不依赖于系统的API,随心所欲打造我们想要的效果,因此这篇文章我将直接

安卓UI设计与开发入门教程

安卓UI设计与开发教程 滑动菜单栏(三)SlidingMenu动画效果的实 安卓UI设计与开发教程 滑动菜单栏(二)开源项目SlidingMenu的示 安卓UI设计与开发教程 滑动菜单栏(一)开源项目SlidingMenu的使 安卓UI设计与开发教程 顶部标题栏(六)实现悬浮式顶部和底部标 安卓UI设计与开发教程 顶部标题栏(五)两种方式实现仿微信标题 安卓UI设计与开发教程 顶部标题栏(四)自定义ActionBar风格和样 安卓UI设计与开发教程 顶部标题栏(三)ActionBar实现层级导航