仿照微信的界面,即ViewPager+Fragment的结合使用
主布局文件:
android:drawableTop="@drawable/weixin_bg"用的是状态选择器,所以要写4个状态选择器,图片的
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity" > <android.support.v4.view.ViewPager
android:id="@+id/vp"
android:layout_width="match_parent"
android:layout_height="match_parent" >
</android.support.v4.view.ViewPager> <RadioGroup
android:id="@+id/rg"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:orientation="horizontal" > <!-- android:button="@null" 表示去掉RadioButton中的圈圈 --> <RadioButton
android:id="@+id/rb_weixin"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:button="@null"
android:drawableTop="@drawable/weixin_bg"
android:gravity="center_vertical"
android:text="微信"
android:textSize="16sp" /> <RadioButton
android:id="@+id/rb_contact"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:button="@null"
android:drawableTop="@drawable/contact_bg"
android:gravity="center_vertical"
android:text="通讯"
android:textSize="16sp" /> <RadioButton
android:id="@+id/rb_found"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:button="@null"
android:drawableTop="@drawable/found_bg"
android:gravity="center_vertical"
android:text="发现"
android:textSize="16sp" /> <RadioButton
android:id="@+id/rb_me"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:button="@null"
android:drawableTop="@drawable/me_bg"
android:gravity="center_vertical"
android:text="我"
android:textSize="16sp" />
</RadioGroup> </RelativeLayout>
MainActivity代码:
public class MainActivity extends FragmentActivity implements OnCheckedChangeListener, OnPageChangeListener {
private static final int WEIXIN = 0;
private static final int CONTACT = 1;
private static final int FOUND= 2;
private static final int ME= 3;
private ViewPager vp;
/**RadioGroup*/
private RadioGroup rg;
//四个RadioButton
private RadioButton rb_weixin;
private RadioButton rb_contact;
private RadioButton rb_found;
private RadioButton rb_me;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
vp = (ViewPager) findViewById(R.id.vp);
rg = (RadioGroup) findViewById(R.id.rg);
rg.setOnCheckedChangeListener(this);
vp.setAdapter(new MainAdapter(getSupportFragmentManager()));
vp.setOnPageChangeListener(this);
rb_weixin = (RadioButton) findViewById(R.id.rb_weixin);
rb_contact = (RadioButton) findViewById(R.id.rb_contact);
rb_found = (RadioButton) findViewById(R.id.rb_found);
rb_me = (RadioButton) findViewById(R.id.rb_me);
//一进入程序就让微信RadioButton显示为被点击状态
rb_weixin.setChecked(true);
}
class MainAdapter extends FragmentPagerAdapter{
List<Fragment> list=new ArrayList<Fragment>();
private WeixinFragment weixinFragment;
private ContactFragment contactFragment;
private FoundFragment foundFragment;
private MeFragment meFragment;
public MainAdapter(FragmentManager fm) {
super(fm);
weixinFragment = new WeixinFragment();
contactFragment = new ContactFragment();
foundFragment = new FoundFragment();
meFragment = new MeFragment();
list.add(weixinFragment);
list.add(contactFragment);
list.add(foundFragment);
list.add(meFragment);
}
@Override
public Fragment getItem(int position) {
Fragment fragment = list.get(position);
return fragment;
}
@Override
public int getCount() {
return list.size();
}
}
//RadioButton被点击时
@Override
public void onCheckedChanged(RadioGroup group, int checkedId) {
switch (checkedId) {
case R.id.rb_weixin:
vp.setCurrentItem(WEIXIN);
break;
case R.id.rb_contact:
vp.setCurrentItem(CONTACT);
break;
case R.id.rb_found:
vp.setCurrentItem(FOUND);
break;
case R.id.rb_me:
vp.setCurrentItem(ME);
break;
default:
break;
}
}
//ViewPager滑动状态改变时
@Override
public void onPageScrollStateChanged(int arg0) {
System.out.println("onPageScrollStateChanged");
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
System.out.println("onPageScrolled");
}
//当ViewPager滑动停止时
@Override
public void onPageSelected(int position) {
System.out.println("onPageSelected");
switch (position) {
case WEIXIN:
rb_weixin.setChecked(true);
break;
case CONTACT:
rb_contact.setChecked(true);
break;
case FOUND:
rb_found.setChecked(true);
break;
case ME:
rb_me.setChecked(true);
break;
default:
break;
}
}
}
这是其中一个Fragment,其它三个一模一样:
public class WeixinFragment extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view = View.inflate(getActivity(), R.layout.fragment_home, null);
return view;
}
}
这样就完成了,这是结果图:

不知道为什么,底部几张图片不能完整地显示,文字也不能居中显示,有没有高手指点一二?
仿照微信的界面,即ViewPager+Fragment的结合使用的更多相关文章
- ViewPager + Fragment 实现类微信界面
在如今的互联网时代,微信已是一个超级App.这篇通过ViewPager + Fragment实现一个类似于微信的界面,之前有用FragmentTabHost实现过类似界面,ViewPager的实现方式 ...
- 【原创】【ViewPager+Fragment】ViewPager中切换界面Fragment被销毁的问题分析
ViewPager中切换界面Fragment被销毁的问题分析 1.使用场景 ViewPager+Fragment实现界面切换,界面数量>=3 2.Fragment生命周期以及与Activ ...
- Android项目Tab类型主界面大总结 Fragment+TabPageIndicator+ViewPager
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/24740977 Android如今实现Tab类型的界面方式越来越多,今天就把常见的 ...
- 转载【ViewPager+Fragment】ViewPager中切换界面Fragment被销毁的问题分析
ViewPager中切换界面Fragment被销毁的问题分析 原文链接 http://www.cnblogs.com/monodin/p/3866441.html 1.使用场景 ViewPager+ ...
- Android ActionBar应用实战,高仿微信主界面的设计
转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/26365683 经过前面两篇文章的学习,我想大家对ActionBar都已经有一个相对 ...
- ViewPager Fragment 懒加载 可见 总结 MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- Android中ViewPager+Fragment取消(禁止)预加载延迟加载(懒加载)问题解决方案
转载请注明出处:http://blog.csdn.net/linglongxin24/article/details/53205878本文出自[DylanAndroid的博客] Android中Vie ...
- 转:ViewPager+Fragment基本使用方法(附源码)
ViewPager+Fragment可以做出多页面滑动效果,让我们的应用程序界面操作起来更加灵活 对于ViewPager和Fragment组件还不熟悉的朋友,可以先看看相关的资料 首先在activit ...
- 使用ViewPager+Fragment来实现带滚动条的多屏滑动-IndicatorFragmentActivity
转载请注明出处:http://blog.csdn.net/singwhatiwanna/article/details/17201587 介绍 在android应用中,多屏滑动是一种很常见的风格,博主 ...
随机推荐
- 自定义alert和confirm
var common = {}; common.showAlert = function (msg) { var html = "<div id='dialog_alert' clas ...
- Android:OpenFire 相关API (持续更新)
基于XMPP协议的聊天服务器.最近会一直更新相关的API. 需要的软件:OpenFire(服务器),Spark(客户端--测试用),Asmack(Jar包) 1.连接服务器的代码 private vo ...
- 基于KNN的相关内容推荐
如果做网站的内容运营,相关内容推荐可以帮助用户更快地寻找和发现感兴趣的信息,从而提升网站内容浏览的流畅性,进而提升网站的价值转化.相关内容 推荐最常见的两块就是“关联推荐”和“相关内容推荐”,关联推荐 ...
- sql语句-排序后加入序号再运算判断取想要的项
select a.id as aid,b.id as bid,a.city,a.cang,a.sid,a.time as atime,b.time as btime,a.price as aprice ...
- sqlDeveloper连接oracle
1.解决oracle11g的ORA-12505问题 启动oraclehome92TNSlistener服务,启动oracleserviceXXXX,XXXX就是你的database SID. < ...
- mybatis结合redis实战二级缓存(六)
之前的文章中我们意见分析了一级缓存.二级缓存的相关源码和基本原理,今天我们来分享下了mybatis二级缓存和redis的结合,当然mybatis二级缓存也可以和ehcache.memcache.OSC ...
- MFC通过ODBC连接Mysql程序
分享到 一键分享 QQ空间 新浪微博 百度云收藏 人人网 腾讯微博 百度相册 开心网 腾讯朋友 百度贴吧 豆瓣网 搜狐微博 百度新首页 QQ好友 和讯微博 更多... 百度分享 MFC通过ODBC连接 ...
- js第一天 点击按钮显示与隐藏
<!DOCTYPE html><html> <head> <meta charset="utf-8" /> <title> ...
- hdu_2227_Find the nondecreasing subsequences_树状数组,离散化
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=2227 题意:给你一个集合,让你求递增子序列有多少个,和树状数组求逆序对差不多,不过数据比较大,要离散化 ...
- hdu_5705_Clock("巴卡斯杯" 中国大学生程序设计竞赛 - 女生专场)
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=5705 题意:给你一个时间和一个角度,问你下一个时针和分针形成给出的角度是什么时候 题解:我们可以将这个 ...