出自:http://my.eoe.cn/fashr314/archive/10358.html
效果如图:
实现代码解析:
MainActivity.java
1.引入布局文件
2.4个标题控件的初始化以及点击事件的监听设置
3.viewpager控件的初始化,获取Fragment对象并保存在容器中,设置viewpager的适配器和监听
4.viewpager的监听OnPageChangeListener方法的实现,主要是标题栏下的指示横线的移动操作。
package com.aven.qqdemo; import java.util.ArrayList; import java.util.List; import android.content.res.Resources; import android.os.Bundle; import android.os.Parcelable; import android.support.v4.app.Fragment; import android.support.v4.app.FragmentActivity; import android.support.v4.app.FragmentManager; import android.support.v4.app.FragmentPagerAdapter; import android.support.v4.app.FragmentTransaction; import android.support.v4.view.ViewPager; import android.support.v4.view.ViewPager.OnPageChangeListener; import android.util.DisplayMetrics; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.Window; import android.view.animation.Animation; import android.view.animation.TranslateAnimation; import android.widget.ImageView; import android.widget.TextView; import com.demo.R; /** * 参考原作者D.Winter基础, * * @author avenwu * iamavenwu@gmail.com * */ public class MainActivity extends FragmentActivity { private static final String TAG = "MainActivity"; private ViewPager mPager; private ArrayList<Fragment> fragmentsList; private ImageView ivBottomLine; private TextView tvTabActivity, tvTabGroups, tvTabFriends, tvTabChat; private int currIndex = 0; private int bottomLineWidth; private int offset = 0; private int position_one; private int position_two; private int position_three; private Resources resources; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.main); resources = getResources(); InitWidth(); InitTextView(); InitViewPager(); } private void InitTextView() { tvTabActivity = (TextView) findViewById(R.id.tv_tab_activity); tvTabGroups = (TextView) findViewById(R.id.tv_tab_groups); tvTabFriends = (TextView) findViewById(R.id.tv_tab_friends); tvTabChat = (TextView) findViewById(R.id.tv_tab_chat); tvTabActivity.setOnClickListener(new MyOnClickListener(0)); tvTabGroups.setOnClickListener(new MyOnClickListener(1)); tvTabFriends.setOnClickListener(new MyOnClickListener(2)); tvTabChat.setOnClickListener(new MyOnClickListener(3)); } private void InitViewPager() { mPager = (ViewPager) findViewById(R.id.vPager); fragmentsList = new ArrayList<Fragment>(); Fragment activityfragment = TestFragment.newInstance("Hello Activity."); Fragment groupFragment = TestFragment.newInstance("Hello Group."); Fragment friendsFragment=TestFragment.newInstance("Hello Friends."); Fragment chatFragment=TestFragment.newInstance("Hello Chat."); fragmentsList.add(activityfragment); fragmentsList.add(groupFragment); fragmentsList.add(friendsFragment); fragmentsList.add(chatFragment); mPager.setAdapter(new MyFragmentPagerAdapter(getSupportFragmentManager(), fragmentsList)); mPager.setCurrentItem(0); mPager.setOnPageChangeListener(new MyOnPageChangeListener()); } private void InitWidth() { ivBottomLine = (ImageView) findViewById(R.id.iv_bottom_line); bottomLineWidth = ivBottomLine.getLayoutParams().width; Log.d(TAG, "cursor imageview width=" + bottomLineWidth); DisplayMetrics dm = new DisplayMetrics(); getWindowManager().getDefaultDisplay().getMetrics(dm); int screenW = dm.widthPixels; offset = (int) ((screenW / 4.0 - bottomLineWidth) / 2); Log.i("MainActivity", "offset=" + offset); position_one = (int) (screenW / 4.0); position_two = position_one * 2; position_three = position_one * 3; } public class MyOnClickListener implements View.OnClickListener { private int index = 0; public MyOnClickListener(int i) { index = i; } @Override public void onClick(View v) { mPager.setCurrentItem(index); } }; public class MyOnPageChangeListener implements OnPageChangeListener { @Override public void onPageSelected(int arg0) { Animation animation = null; switch (arg0) { case 0: if (currIndex == 1) { animation = new TranslateAnimation(position_one, 0, 0, 0); tvTabGroups.setTextColor(resources.getColor(R.color.lightwhite)); } else if (currIndex == 2) { animation = new TranslateAnimation(position_two, 0, 0, 0); tvTabFriends.setTextColor(resources.getColor(R.color.lightwhite)); } else if (currIndex == 3) { animation = new TranslateAnimation(position_three, 0, 0, 0); tvTabChat.setTextColor(resources.getColor(R.color.lightwhite)); } tvTabActivity.setTextColor(resources.getColor(R.color.white)); break; case 1: if (currIndex == 0) { animation = new TranslateAnimation(0, position_one, 0, 0); tvTabActivity.setTextColor(resources.getColor(R.color.lightwhite)); } else if (currIndex == 2) { animation = new TranslateAnimation(position_two, position_one, 0, 0); tvTabFriends.setTextColor(resources.getColor(R.color.lightwhite)); } else if (currIndex == 3) { animation = new TranslateAnimation(position_three, position_one, 0, 0); tvTabChat.setTextColor(resources.getColor(R.color.lightwhite)); } tvTabGroups.setTextColor(resources.getColor(R.color.white)); break; case 2: if (currIndex == 0) { animation = new TranslateAnimation(0, position_two, 0, 0); tvTabActivity.setTextColor(resources.getColor(R.color.lightwhite)); } else if (currIndex == 1) { animation = new TranslateAnimation(position_one, position_two, 0, 0); tvTabGroups.setTextColor(resources.getColor(R.color.lightwhite)); } else if (currIndex == 3) { animation = new TranslateAnimation(position_three, position_two, 0, 0); tvTabChat.setTextColor(resources.getColor(R.color.lightwhite)); } tvTabFriends.setTextColor(resources.getColor(R.color.white)); break; case 3: if (currIndex == 0) { animation = new TranslateAnimation(0, position_three, 0, 0); tvTabActivity.setTextColor(resources.getColor(R.color.lightwhite)); } else if (currIndex == 1) { animation = new TranslateAnimation(position_one, position_three, 0, 0); tvTabGroups.setTextColor(resources.getColor(R.color.lightwhite)); } else if (currIndex == 2) { animation = new TranslateAnimation(position_two, position_three, 0, 0); tvTabFriends.setTextColor(resources.getColor(R.color.lightwhite)); } tvTabChat.setTextColor(resources.getColor(R.color.white)); break; } currIndex = arg0; animation.setFillAfter(true); animation.setDuration(300); ivBottomLine.startAnimation(animation); } @Override public void onPageScrolled(int arg0, float arg1, int arg2) { } @Override public void onPageScrollStateChanged(int arg0) { } } }
TestFragment
获取Fragment对应的布局,并且设置相应的参数。
package com.aven.qqdemo; import com.demo.R; import android.os.Bundle; import android.support.v4.app.Fragment; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.TextView; public class TestFragment extends Fragment { private static final String TAG = "TestFragment"; private String hello;// = "hello android"; private String defaultHello = "default value"; static TestFragment newInstance(String s) { TestFragment newFragment = new TestFragment(); Bundle bundle = new Bundle(); bundle.putString("hello", s); newFragment.setArguments(bundle); return newFragment; } @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Log.d(TAG, "TestFragment-----onCreate"); Bundle args = getArguments(); hello = args != null ? args.getString("hello") : defaultHello; } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) { Log.d(TAG, "TestFragment-----onCreateView"); View view = inflater.inflate(R.layout.lay1, container, false); TextView viewhello = (TextView) view.findViewById(R.id.tv_hello); viewhello.setText(hello); return view; } @Override public void onDestroy() { super.onDestroy(); Log.d(TAG, "TestFragment-----onDestroy"); } }
MyFragmentPagerAdapter
对包含Fragment对象的容器进行适配。
package com.aven.qqdemo; import java.util.ArrayList; import android.support.v4.app.Fragment; import android.support.v4.app.FragmentManager; import android.support.v4.app.FragmentPagerAdapter; public class MyFragmentPagerAdapter extends FragmentPagerAdapter { private ArrayList<Fragment> fragmentsList; public MyFragmentPagerAdapter(FragmentManager fm) { super(fm); } public MyFragmentPagerAdapter(FragmentManager fm, ArrayList<Fragment> fragments) { super(fm); this.fragmentsList = fragments; } @Override public int getCount() { return fragmentsList.size(); } @Override public Fragment getItem(int arg0) { return fragmentsList.get(arg0); } @Override public int getItemPosition(Object object) { return super.getItemPosition(object); } }
代码下载地址
相关推荐
总之,"ViewPager+Fragment实现仿QQ选项卡"是Android应用开发中一种实用的设计模式,通过结合使用ViewPager、Fragment和TabLayout,可以创建出类似QQ底部导航栏的交互体验,同时提供了灵活的界面布局和内容管理。...
最后,"Android ViewPager+Fragment实现QQ界面" 应该是实际的源代码文件,包含了所有相关的类和资源文件,供开发者研究和学习。 总的来说,通过学习和实践这个项目,开发者可以深入理解 `ViewPager` 和 `Fragment` ...
【ViewPager+Fragment实现QQ界面】是一个Android开发中的实践项目,主要涉及到的是UI设计与动态页面切换的技术。在Android应用开发中,ViewPager是一个非常常见的组件,它允许用户左右滑动来浏览多个视图,通常用于...
这个"Android ViewPager+Fragment实现QQ界面"的项目涵盖了Android开发中的多个核心知识点,包括UI设计、数据存储、组件通信、性能优化等,对于学生来说,是一个很好的学习和实践平台,有助于加深对Android开发的理解...
总之,`ViewPager`与`Fragment`的结合可以创建出高度可定制的用户界面,通过自定义`ViewPager`处理滑动冲突,可以实现既流畅又无冲突的交互体验。在实际开发中,理解这两个组件的工作原理并熟练掌握其使用方式,对于...
在这个"Android ViewPager+Fragment实现QQ界面"的项目中,我们将深入探讨如何利用这两个关键组件来复现QQ的界面交互。 首先,`ViewPager`是Android Support Library的一部分,它提供了一个可以水平滑动的视图容器,...
Android ViewPager+Fragment实现QQ界面.zip项目安卓应用源码下载Android ViewPager+Fragment实现QQ界面.zip项目安卓应用源码下载 1.适合学生毕业设计研究参考 2.适合个人学习研究参考 3.适合公司开发项目技术参考
在`ViewPager`和`Fragment`的结合使用中,`Fragment`可以包含复杂的视图结构,使得用户可以在滑动时体验到平滑的页面过渡。 接下来,我们讨论`Toolbar`。`Toolbar`是Android 5.0(Lollipop)引入的新组件,它是对`...
实现QQ界面,我们需要考虑以下步骤: 1. **创建Fragment**:首先,为QQ的不同功能(如聊天列表、联系人列表、个人信息等)创建对应的Fragment。每个Fragment都应该有自己的布局文件,并在对应的Java或Kotlin类中...
在本示例项目“Android程序研发源码Android ViewPager+Fragment实现QQ界面”中,开发者利用这两种技术来模仿QQ应用的界面布局,提供了类似的功能体验。下面我们将深入探讨这两个组件以及它们在构建复杂界面时的角色...
在Android开发中,`ViewPager`和`Fragment`的结合使用是一种常见的实现页面滑动切换的手段,尤其适用于创建带有多个视图的复杂界面。`ViewPager`允许用户通过水平滑动来浏览相邻的`Fragment`,而`Fragment`则用于...
在这个“Android源码——ViewPager+Fragment实现QQ界面”的项目中,我们将深入探讨这两个组件的使用方式以及如何将它们结合来创建类似QQ的交互体验。 首先,ViewPager是Android SDK中的一个视图容器,它允许用户...
在提供的压缩包文件中,"Android ViewPager+Fragment实现QQ界面"可能是项目源代码,可以从中学习到具体实现细节。`1-1209142132550-L.png`和`1_120914213532_1.png`可能是项目截图,帮助理解UI设计和布局结构。 ...
这个“Android源码——ViewPager+Fragment实现QQ界面”的项目,旨在帮助开发者了解如何利用这两个工具来创建类似QQ聊天应用的交互体验。 首先,ViewPager是一个强大的视图切换器,它允许用户通过水平滑动来浏览多个...
将 `ViewPager` 与 `Fragment` 结合使用,可以实现更灵活、动态的用户界面。`ViewPager` 使用适配器(通常是 `FragmentPagerAdapter` 或 `FragmentStatePagerAdapter`)来管理其内部的 `Fragment` 集合。适配器负责...
在Android开发中,`ViewPager` 是一个非常常用的组件,它允许用户通过左右滑动来切换不同的页面,通常与`Fragment`结合使用以实现更丰富的界面交互。本教程将深入讲解如何利用`ViewPager`和`Fragment`来实现左右滑动...
此外,`ViewPager`配合`Fragment`的使用还有其他高级用法,如使用`TabLayout`实现标签页功能,或者使用`FragmentTransaction`动态添加和替换`Fragment`。 总结,`ViewPager+Fragment+滚动条`的组合是Android开发中...
通过以上步骤,我们就可以成功地使用`ViewPager`和`Fragment`实现类似QQ底部导航栏的功能。这个设计模式在许多现代Android应用中被广泛采用,因为它提供了高效的内容切换方式,并且易于扩展和维护。在实际项目中,还...