• ViewPager+RadioGroup实现标题栏切换,Fragment切换


    1.说明:

    在使用RadioGroup做标题栏切换的时候,跟ViewPager的滑动有冲突,最后查看了源代码+断点调试攻克了一些碰到的问题,写一篇博客总结一下,有相同需求的朋友能够借鉴一下,自己以后实用到也方便复习。


    2.代码结构,以及功能说明

        1).主界面的Fragment切换使用ViewPager实现

        2).标题栏用RadioGroup实现

        3).实现这两个控件的监听函数,改变背景,改变字体颜色,设置当前Fragment,设置当前选中RadioButton


    3.主界面代码实现

    public class MainActivity extends FragmentActivity {
    	private RadioButton homeFollow,homeRecommend,homeLocation;
    	private ViewPager  vPager;
    	private List<Fragment> list=new ArrayList<Fragment>();
    	private MyFragmentAdapter adapter;
    	private final int[] array=new int[]{R.id.home_follow,R.id.home_recommend,R.id.home_location};
    
    	@Override
    	protected void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.view_pager_test);
    		
    		FollowFragment topFragment = new FollowFragment();
    		RecommendFragment  hotFragment = new RecommendFragment();
    		LocationFragment locationFragment = new LocationFragment();
    		list.add(topFragment);
    		list.add(hotFragment);
    		list.add(locationFragment);
    		
    		vPager = (ViewPager) findViewById(R.id.viewpager_home);
    		adapter = new MyFragmentAdapter(getSupportFragmentManager(), list);
    		vPager.setAdapter(adapter);
    		vPager.setOffscreenPageLimit(2);
    		vPager.setCurrentItem(1);
    		vPager.setOnPageChangeListener(pageChangeListener);
    		
    		homeFollow=(RadioButton) findViewById(R.id.home_follow);
    		homeRecommend=(RadioButton) findViewById(R.id.home_recommend);
    		homeLocation=(RadioButton) findViewById(R.id.home_location);
    		
    		RadioGroup group=(RadioGroup) findViewById(R.id.home_page_select);
    		group.setOnCheckedChangeListener(new OnCheckedChangeListener() {
    			@Override
    			public void onCheckedChanged(RadioGroup group,int checkedId){
    				//设置了ViewPager的当前item就会触发ViewPager的SimpleOnPageChangeListener监听函数
    				switch (checkedId){
    				case R.id.home_follow:
    					vPager.setCurrentItem(0);
    					break;
    				case R.id.home_recommend:
    					vPager.setCurrentItem(1);
    					break;
    				case R.id.home_location:
    					vPager.setCurrentItem(2);
    					break;
    				}
    			}
    		});
    	}
    	
    	SimpleOnPageChangeListener pageChangeListener=new SimpleOnPageChangeListener(){
    		public void onPageSelected(int position){
    			change(array[position]);
    		}
    	};
    	
    	/**
    	 * 改变背景颜色,背景图片
    	 * @param checkedId
    	 */
    	private void change(int checkedId){
    		//改变背景颜色
    		homeFollow.setBackgroundResource(R.drawable.icon_top_normal);
    		homeRecommend.setBackgroundResource(R.drawable.icon_recommend_normal);
    		homeLocation.setBackgroundResource(R.drawable.icon_location_normal);
    		
    		//改变字体颜色
    		homeFollow.setTextColor(getResources().getColor(R.color.white_normal));
    		homeRecommend.setTextColor(getResources().getColor(R.color.white_normal));
    		homeLocation.setTextColor(getResources().getColor(R.color.white_normal));
    		
    		switch (checkedId){
    		case R.id.home_follow:
    			homeFollow.setBackgroundResource(R.drawable.icon_top_select);
    			homeFollow.setTextColor(getResources().getColor(R.color.balck_normal));
    			homeFollow.setChecked(true);
    			break;
    		case R.id.home_recommend:
    			homeRecommend.setBackgroundResource(R.drawable.icon_recommend_select);
    			homeRecommend.setTextColor(getResources().getColor(R.color.balck_normal));
    			homeRecommend.setChecked(true);
    			break;
    		case R.id.home_location:
    			homeLocation.setBackgroundResource(R.drawable.icon_location_select);
    			homeLocation.setTextColor(getResources().getColor(R.color.balck_normal));
    			homeLocation.setChecked(true);
    			break;
    		}
    	}
    }


    4.ViewPager适配器

    public class MyFragmentAdapter extends FragmentStatePagerAdapter {
    	private List<Fragment>list;
    	public MyFragmentAdapter(FragmentManager fm, List<Fragment> list) {
    		super(fm);
    		this.list = list;
    	}
    
    	public MyFragmentAdapter(FragmentManager fm) {
    		super(fm);
    	}
    
    	@Override
    	public Fragment getItem(int arg0) {
    		return list.get(arg0);
    	}
    
    	@Override
    	public int getCount() {
    		return list.size();
    	}
    }



    5.主界面布局文件

    <span style="font-size:14px;"><FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical" >
    
        <android.support.v4.view.ViewPager
            android:id="@+id/viewpager_home"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    
        <RelativeLayout
            android:id="@+id/login_success_title"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="#78000000"
            android:paddingLeft="5dip"
            android:paddingRight="5dip" >
    
            <RadioGroup
                android:id="@+id/home_page_select"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_centerHorizontal="true"
                android:layout_centerVertical="true"
                android:orientation="horizontal"
                android:paddingBottom="4dp"
                android:paddingTop="4dp" >
    
                <RadioButton
                    android:id="@+id/home_follow"
                    android:background="@drawable/icon_top_normal"
                    android:button="@null"
                    android:gravity="center"
                    android:text="关注"
                    android:textColor="@color/select_home_radio_color" />
    
                <RadioButton
                    android:id="@+id/home_recommend"
                    android:background="@drawable/icon_recommend_select"
                    android:button="@null"
                    android:checked="true"
                    android:gravity="center"
                    android:text="推荐"
                    android:textColor="@color/select_home_radio_color" />
    
                <RadioButton
                    android:id="@+id/home_location"
                    android:background="@drawable/icon_location_normal"
                    android:button="@null"
                    android:gravity="center"
                    android:text="位置"
                    android:textColor="@color/select_home_radio_color" />
            </RadioGroup>
        </RelativeLayout>
    
    </FrameLayout></span>


     6.效果图例如以下:

         


    另一些布局文件,跟资源文件我就不贴出来了,有须要的能够直接下载源代码

    点击下载源代码


    推荐下自己创建的android QQ群:202928390 欢迎大家的增加.


    推荐一个Android开发人员必关注公众号,每周都有原创干货


  • 相关阅读:
    单例设计模式
    HashMap 排序
    代理、动态代理
    冒泡排序 、二分查找、快速排序
    Azure powershell 订阅登录管理
    cmdbuild -2.4.3 在Centos7部署
    Zabbix3.0 安装部署
    nginx 一键安装
    通过菜单一键安装mysql
    Rsync同步工具
  • 原文地址:https://www.cnblogs.com/clnchanpin/p/7102138.html
Copyright © 2020-2023  润新知