Android仿新浪新闻SlidingMenu界面的实现 .
先看看原图:
如图所示,这种侧滑效果以另一种方式替代了原先tab导航的那种用户体验方式
给人耳目一新的感觉,现已被广大知名应用所效仿,如新浪新闻,网易新闻,人人网等
那么这种效果该如何实现呢?那就需要用到一个开源库SlidingMenu
Github地址:https://github.com/jfeinstein10/SlidingMenu
里面包含了demo示例,相关效果图如下:
同时该库又依赖另一个开源库ActionBarSherkLock ,有关该库的介绍,请看此博文http://blog.csdn.net/geniuseoe2012/article/details/9046487
大家最好先把官方demo跑一遍,理清里边的依赖关系以及对库的基本使用,这样自己运用到项目当中就可以得心应手了
OK,最后言归正传,看看新浪新闻的侧滑实现,先上山寨版效果图:
代码片段:
- public class MainActivity extends SlidingFragmentActivity implements OnClickListener{
- private static final CommonLog log = LogFactory.createLog();
- private String mTitle;
- private Fragment mContent;
- private ImageView mLeftIcon;
- private ImageView mRightIcon;
- private TextView mTitleTextView;
- private FragmentControlCenter mControlCenter;
- @Override
- public void onCreate(Bundle savedInstanceState) {
- // TODO Auto-generated method stub
- super.onCreate(savedInstanceState);
- mControlCenter = FragmentControlCenter.getInstance(this);
- setupViews();
- initData();
- }
- private void setupViews(){
- setContentView(R.layout.main_slidemenu_layout);
- initActionBar();
- initSlideMenu();
- }
- private void initSlideMenu(){
- FragmentModel fragmentModel = mControlCenter.getTouTiaoFragmentModel();
- switchContent(fragmentModel);
- SlidingMenu sm = getSlidingMenu();
- sm.setMode(SlidingMenu.LEFT_RIGHT);
- setBehindContentView(R.layout.left_menu_frame);
- sm.setSlidingEnabled(true);
- sm.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);
- sm.setShadowWidthRes(R.dimen.shadow_width);
- sm.setShadowDrawable(R.drawable.shadow);
- getSupportActionBar().setDisplayHomeAsUpEnabled(true);
- getSupportFragmentManager()
- .beginTransaction()
- .replace(R.id.left_menu_frame, new NavigationFragment())
- .commit();
- sm.setBehindOffsetRes(R.dimen.slidingmenu_offset);
- sm.setBehindScrollScale(0);
- sm.setFadeDegree(0.25f);
- sm.setSecondaryMenu(R.layout.right_menu_frame);
- sm.setSecondaryShadowDrawable(R.drawable.shadow);
- getSupportFragmentManager()
- .beginTransaction()
- .replace(R.id.right_menu_frame, new SettingFragment())
- .commit();
- }
- private void initActionBar(){
- ActionBar actionBar = getSupportActionBar();
- actionBar.setCustomView(R.layout.actionbar_layout);
- actionBar.setDisplayShowCustomEnabled(true);
- actionBar.setDisplayShowHomeEnabled(false);
- mLeftIcon = (ImageView) findViewById(R.id.iv_left_icon);
- mRightIcon = (ImageView) findViewById(R.id.iv_right_icon);
- mLeftIcon.setOnClickListener(this);
- mRightIcon.setOnClickListener(this);
- mTitleTextView = (TextView) findViewById(R.id.tv_title);
- }
- private void initData(){
- }
- public void switchContent(final FragmentModel fragment) {
- mTitle = fragment.mTitle;
- mContent = fragment.mFragment;
- getSupportFragmentManager()
- .beginTransaction()
- .replace(R.id.content_frame, mContent)
- .commit();
- Handler h = new Handler();
- h.postDelayed(new Runnable() {
- public void run() {
- getSlidingMenu().showContent();
- }
- }, 50);
- mTitleTextView.setText(mTitle);
- }
- @Override
- public void onClick(View view) {
- switch(view.getId()){
- case R.id.iv_left_icon:
- toggle();
- break;
- case R.id.iv_right_icon:
- showSecondaryMenu();
- break;
- }
- }
- }
这里actionbar使用自定义布局,主要是使用ActionBarSherklock里的默认布局不知道怎么把title标题居中
找了半天没发现相关属性,如果有童鞋知道麻烦告知
NavigationFragment是左侧菜单
- public class NavigationFragment extends Fragment implements OnCheckedChangeListener, OnClickListener{
- private static final CommonLog log = LogFactory.createLog();
- private View mView;
- private RadioGroup m_radioGroup;
- private ImageButton m_AddButton;
- private FragmentControlCenter mControlCenter;
- public NavigationFragment(){
- }
- @Override
- public void onCreate(Bundle savedInstanceState) {
- // TODO Auto-generated method stub
- super.onCreate(savedInstanceState);
- log.e("NavigationFragment onCreate");
- mControlCenter = FragmentControlCenter.getInstance(getActivity());
- }
- @Override
- public void onDestroy() {
- // TODO Auto-generated method stub
- super.onDestroy();
- log.e("NavigationFragment onDestroy");
- }
- @Override
- public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
- log.e("NavigationFragment onCreateView");
- mView = inflater.inflate(R.layout.navitation_channel_layout, null);
- return mView;
- }
- @Override
- public void onActivityCreated(Bundle savedInstanceState) {
- super.onActivityCreated(savedInstanceState);
- log.e("NavigationFragment onActivityCreated");
- setupViews();
- }
- private void setupViews(){
- m_radioGroup = (RadioGroup) mView.findViewById(R.id.nav_radiogroup);
- ((RadioButton) m_radioGroup.getChildAt(0)).toggle();
- m_radioGroup.setOnCheckedChangeListener(this);
- m_AddButton = (ImageButton) mView.findViewById(R.id.ib_add_content);
- m_AddButton.setOnClickListener(this);
- }
- @Override
- public void onCheckedChanged(RadioGroup arg0, int id) {
- switch(id){
- case R.id.rb_toutiao:
- goTouTiaoFragment();
- break;
- case R.id.rb_yule:
- goYuLeFragment();
- break;
- case R.id.rb_tech:
- goTechFragment();
- break;
- case R.id.rb_blog:
- goBlogFragment();
- break;
- }
- }
- private void goTouTiaoFragment(){
- if (getActivity() == null)
- return;
- FragmentModel fragmentModel = mControlCenter.getTouTiaoFragmentModel();
- if (getActivity() instanceof MainActivity) {
- MainActivity ra = (MainActivity) getActivity();
- ra.switchContent(fragmentModel);
- }
- }
- private void goYuLeFragment(){
- if (getActivity() == null)
- return;
- FragmentModel fragmentModel = mControlCenter.getYuLeFragmentModel();
- if (getActivity() instanceof MainActivity) {
- MainActivity ra = (MainActivity) getActivity();
- ra.switchContent(fragmentModel);
- }
- }
- private void goTechFragment(){
- if (getActivity() == null)
- return;
- FragmentModel fragmentModel = mControlCenter.getTechFragmentModel();
- if (getActivity() instanceof MainActivity) {
- MainActivity ra = (MainActivity) getActivity();
- ra.switchContent(fragmentModel);
- }
- }
- private void goBlogFragment(){
- if (getActivity() == null)
- return;
- FragmentModel fragmentModel = mControlCenter.getBlogFragmentModel();
- if (getActivity() instanceof MainActivity) {
- MainActivity ra = (MainActivity) getActivity();
- ra.switchContent(fragmentModel);
- }
- }
- @Override
- public void onClick(View v) {
- switch(v.getId()){
- case R.id.ib_add_content:
- Toast.makeText(getActivity(), "添加尼妹,现在没内容!!!", Toast.LENGTH_SHORT).show();
- break;
- }
- }
- }
SettingFragment是右侧菜单
- public class SettingFragment extends Fragment{
- private static final CommonLog log = LogFactory.createLog();
- private View mView;
- public SettingFragment(){
- }
- @Override
- public void onCreate(Bundle savedInstanceState) {
- // TODO Auto-generated method stub
- super.onCreate(savedInstanceState);
- log.e("SettingFragment onCreate");
- }
- @Override
- public View onCreateView(LayoutInflater inflater, ViewGroup container,
- Bundle savedInstanceState) {
- log.e("SettingFragment onCreateView");
- View view = inflater.inflate(R.layout.setting_layout, null);
- return view;
- }
- @Override
- public void onActivityCreated(Bundle savedInstanceState) {
- super.onActivityCreated(savedInstanceState);
- log.e("SettingFragment onActivityCreated");
- setupViews();
- }
- private void setupViews(){
- }
- @Override
- public void onDestroy() {
- // TODO Auto-generated method stub
- super.onDestroy();
- log.e("SettingFragment onDestroy");
- }
- }
两个fragment是附在主activity上的,其它的大伙自个儿down代码看吧
附上链接工程:
http://download.csdn.net/detail/geniuseoe2012/5832027
压缩包解开后有如下目录:
前面三个都是链接库,彼此又有依赖,最后工程再依赖前面三者,添加完毕后就可以正常running了
Android仿新浪新闻SlidingMenu界面的实现 .的更多相关文章
- Lance老师UI系列教程第八课->新浪新闻SlidingMenu界面的实现
UI系列教程第八课:Lance老师UI系列教程第八课->新浪新闻SlidingMenu界面的实现 今天蓝老师要讲的是关于新浪新闻侧滑界面的实现.先看看原图: 如图所示,这种侧滑效果以另一种方式替 ...
- android仿新浪引导界面
最近在研究如何做出仿微信,仿新浪等应用,第一次安装使用的使用展示应用程序的新特性和用法. 实现功能:左右手势滑屏 底部小圆点随当前显示页跳动 浮动按钮显示.当触屏事件发生显示,否则就渐渐消失 先转个文 ...
- jquery实现隐藏显示层动画效果、仿新浪字符动态输入、tab效果
已经有两年多没登陆csdn账号了,中间做了些旁的事,可是现在却还是回归程序,但改做前端了,虽然很多东西都已忘得差不多了,但还是应该摆正心态,慢慢来,在前端漫游,做一只快乐双鱼. 路是一步一步走出来的, ...
- 门户级UGC系统的技术进化路线——新浪新闻评论系统的架构演进和经验总结(转)
add by zhj:先收藏了 摘要:评论系统是所有门户网站的核心标准服务组件之一.本文作者曾负责新浪网评论系统多年,这套系统不仅服务于门户新闻业务,还包括调查.投票等产品,经历了从单机到多机再到集群 ...
- selenium+BeautifulSoup+phantomjs爬取新浪新闻
一 下载phantomjs,把phantomjs.exe的文件路径加到环境变量中,也可以phantomjs.exe拷贝到一个已存在的环境变量路径中,比如我用的anaconda,我把phantomjs. ...
- Python_网络爬虫(新浪新闻抓取)
爬取前的准备: BeautifulSoup的导入:pip install BeautifulSoup4 requests的导入:pip install requests 下载jupyter noteb ...
- 小爬新浪新闻AFCCL
1.任务目标: 爬取新浪新闻AFCCL的文章:文章标题.时间.来源.内容.评论数等信息. 2.目标网页: http://sports.sina.com.cn/z/AFCCL/ 3.网页分析 4.源代码 ...
- Python爬虫:新浪新闻详情页的数据抓取(函数版)
上一篇文章<Python爬虫:抓取新浪新闻数据>详细解说了如何抓取新浪新闻详情页的相关数据,但代码的构建不利于后续扩展,每次抓取新的详情页时都需要重新写一遍,因此,我们需要将其整理成函数, ...
- python3爬虫-爬取新浪新闻首页所有新闻标题
准备工作:安装requests和BeautifulSoup4.打开cmd,输入如下命令 pip install requests pip install BeautifulSoup4 打开我们要爬取的 ...
随机推荐
- BZOJ1564 NOI2009二叉查找树(区间dp)
首先按数据值排序,那么连续一段区间的dfs序一定也是连续的. 将权值离散化,设f[i][j][k]为i到j区间内所有点的权值都>=k的最小代价,转移时枚举根考虑是否修改权值即可. #includ ...
- 洛谷 P2055 [ZJOI2009]假期的宿舍
洛谷 P2055 题目描述 学校放假了 · · · · · · 有些同学回家了,而有些同学则有以前的好朋友来探访,那么住宿就是一个问题.比如 A 和 B 都是学校的学生,A 要回家,而 C 来看B,C ...
- 利用MSXSL.exe绕过AppLocker应用程序控制策略
1.需要用到微软工具MSXSL.exe,msxsl.exe是微软用于命令行下处理XSL的一个程序,所以通过他,我们可以执行JavaScript进而执行系统命令,其下载地址为: https://www. ...
- 常用Transformation算子
map 产生的键值对是tupple, split分隔出来的是数组 一.常用Transformation算子 (map .flatMap .filter .groupByKey .reduc ...
- 【bzoj4811】由乃的OJ
Portal --> bzoj4811 Solution 这题可以用树剖+线段树做也可以用LCT做,不过大体思路是一样的 (接下来先讲的是树剖+线段树的做法,再提LCT的做法) 首先位 ...
- 《用Apache HttpClient实现URL重定向》
作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs 很多网站都使用了URL重定向技术,把一个原始请求从一个位置路由到另一个位置.原因可能是多方面的,比如域名转 ...
- Vue.js随笔四(方法的声明和使用)
1.首先你需要新建路由,这个就不多说了 2.然后在你的新的.vue里面需要如下所示的添加methods:{方法},然后按钮的里面你会看到v-on:click,这就是点击这个按钮会触发的动作,这个就是触 ...
- JS中的匿名函数自执行、函数声明与函数表达式
先看一段jQuery源码中匿名函数自执行的例子: (function( window, undefined ) { // jquery code })(window); 另外一种常见的写法: +fun ...
- NOIP 2015 提高组 Day2
期望得分:100+10+60=170 实际得分:100+10+35=145 http://www.cogs.pro/cogs/page/page.php?aid=16 T1 跳石头 时间限制:1 s ...
- 一张图搞懂Spring bean的完整生命周期
一张图搞懂Spring bean的生命周期,从Spring容器启动到容器销毁bean的全过程,包括下面一系列的流程,了解这些流程对我们想在其中任何一个环节怎么操作bean的生成及修饰是非常有帮助的. ...