android ViewPager 实现QQ主界面,附带ViewFlipper,ViewFlow用法

本文主要是介绍android ViewPager 实现QQ主界面,附带ViewFlipper,ViewFlow用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

开篇

首页只是作为ViewPager,ViewFlipper,ViewFlow的入口,提供三个Button进行跳转。


1. ViewPager

先看看官方文档怎么介绍ViewPager的:http://developer.android.com/reference/android/support/v4/view/ViewPager.html

继承关系如下:

java.lang.Object

android.view.View

android.view.ViewGroup

android.support.v4.view.ViewPager

ViewPager做为容器类,可以结合View(Layout)和Fragment(Android 3.0 才引入的),官方文档说ViewPager+Fragment配合使用更好。ViewPager不在android sdk 自带jar包中,来源google 的补充组件android-support-v4.jar,没有的话可以通过eclipse下载和自己下载再添加到相应的工程中,本例用的是android-support-v13.jar,完全兼容android-support-v4.jar,看看android-support-v13.jar的目录结构:

[android-support-v13.jar下载]

切入正题,ViewPager用法如下:

配置文件:viewpager_layout.xml:

[java] view plain copy print ?
  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. <android.support.v4.view.ViewPager
  6. android:id="@+id/viewpager"
  7. android:layout_width="fill_parent"
  8. android:layout_height="wrap_content" />
  9. </RelativeLayout>
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="fill_parent"
android:layout_height="wrap_content" />
</RelativeLayout>


源文件如下ViewPagerActivity.java如下:


[java] view plain copy print ?
  1. package com.xyz.vvv.ViewPager;
  2. import java.util.ArrayList;
  3. import com.xyz.vvv.R;
  4. import android.app.ActionBar;
  5. import android.app.ActionBar.LayoutParams;
  6. import android.app.ActionBar.Tab;
  7. import android.app.ActionBar.TabListener;
  8. import android.app.Activity;
  9. import android.app.Fragment;
  10. import android.app.FragmentTransaction;
  11. import android.content.Context;
  12. import android.os.Bundle;
  13. import android.support.v13.app.FragmentPagerAdapter;
  14. import android.support.v4.view.ViewPager;
  15. import android.support.v4.view.ViewPager.OnPageChangeListener;
  16. import android.view.LayoutInflater;
  17. import android.view.View;
  18. public class ViewPagerActivityextends Activity {
  19. private ViewPager mViewPager;
  20. private ViewPagerAdapter mAdapter;
  21. private ActionBar mTabBar;
  22. @Override
  23. protected void onCreate(Bundle savedInstanceState) {
  24. // TODO Auto-generated method stub
  25. super.onCreate(savedInstanceState);
  26. setContentView(R.layout.viewpager_layout);
  27. mViewPager = (ViewPager) findViewById(R.id.viewpager);
  28. mAdapter = new ViewPagerAdapter(this, mViewPager);
  29. mTabBar = getActionBar();
  30. mAdapter.addTab(mTabBar.newTab().setIcon(R.drawable.tab_icon_qworld),
  31. FirstFragment.class,null);
  32. mAdapter.addTab(mTabBar.newTab().setIcon(R.drawable.tab_icon_group),
  33. SecondFragment.class,null);
  34. mAdapter.addTab(mTabBar.newTab().setIcon(R.drawable.tab_icon_friends),
  35. ThreeFragment.class,null);
  36. mAdapter.addTab(mTabBar.newTab().setIcon(R.drawable.tab_icon_recent),
  37. FourFragment.class,null);
  38. }
  39. private View getCustomView() {
  40. return getLayoutInflater().inflate(R.layout.title_panel_layout,null);
  41. }
  42. private staticclass ViewPagerAdapter extends FragmentPagerAdapter
  43. implements TabListener, OnPageChangeListener {
  44. private Context mContext;
  45. private ActionBar mActionBar =null;
  46. private ViewPager mViewPager =null;
  47. private ArrayList<TabInfo> mTabList =new ArrayList<TabInfo>();
  48. public ViewPagerAdapter(Activity activity, ViewPager viewPager) {
  49. // TODO Auto-generated constructor stub
  50. super(activity.getFragmentManager());
  51. mContext = activity;
  52. mActionBar = activity.getActionBar();
  53. /*
  54. * mActionBar.setCustomView(getCustomView(), new LayoutParams(
  55. * LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
  56. */
  57. mActionBar.setDisplayOptions(mActionBar.getDisplayOptions()
  58. ^ ActionBar.DISPLAY_SHOW_HOME
  59. ^ ActionBar.DISPLAY_SHOW_TITLE, ActionBar.DISPLAY_SHOW_HOME
  60. | ActionBar.DISPLAY_SHOW_TITLE);
  61. mActionBar.setDisplayShowHomeEnabled(false);
  62. mActionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
  63. mViewPager = viewPager;
  64. mViewPager.setAdapter(this);
  65. mViewPager.setOnPageChangeListener(this);
  66. }
  67. /** Override OnPageChangeListener start **/
  68. @Override
  69. public void onPageScrollStateChanged(int arg0) {
  70. // TODO Auto-generated method stub
  71. }
  72. @Override
  73. public void onPageScrolled(int position,float positionOffset,
  74. int positionOffsetPixels) {
  75. // TODO Auto-generated method stub
  76. }
  77. @Override
  78. public void onPageSelected(int position) {
  79. // TODO Auto-generated method stub
  80. mActionBar.setSelectedNavigationItem(position);
  81. }
  82. /** Override OnPageChangeListener end **/
  83. /** Override TabListener start **/
  84. @Override
  85. public void onTabSelected(Tab tab, FragmentTransaction ft) {
  86. // TODO Auto-generated method stub
  87. Object tag = tab.getTag();
  88. for (int i =0; i < mTabList.size(); i++) {
  89. if (mTabList.get(i) == tag) {
  90. mViewPager.setCurrentItem(i);
  91. }
  92. }
  93. }
  94. @Override
  95. public void onTabUnselected(Tab tab, FragmentTransaction ft) {
  96. // TODO Auto-generated method stub
  97. }
  98. @Override
  99. public void onTabReselected(Tab tab, FragmentTransaction ft) {
  100. // TODO Auto-generated method stub
  101. }
  102. /** Override TabListener end **/
  103. /** Override FragmentPagerAdapter start **/
  104. @Override
  105. public Fragment getItem(int position) {
  106. // TODO Auto-generated method stub
  107. TabInfo tab = mTabList.get(position);
  108. if (tab.fragment == null) {
  109. tab.fragment = Fragment.instantiate(mContext,
  110. tab.clazz.getName(), tab.bundle);
  111. }
  112. return tab.fragment;
  113. }
  114. @Override
  115. public int getCount() {
  116. // TODO Auto-generated method stub
  117. return mTabList.size();
  118. }
  119. /** Override FragmentPagerAdapter end **/
  120. private View getCustomView() {
  121. LayoutInflater inflater = (LayoutInflater) mContext
  122. .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  123. return inflater.inflate(R.layout.title_panel_layout,null);
  124. }
  125. public void addTab(Tab tab, Class<?> clazz, Bundle bundle) {
  126. TabInfo tabInfo = new TabInfo(clazz, bundle);
  127. tab.setTag(tabInfo);
  128. tab.setTabListener(this);
  129. mTabList.add(tabInfo);
  130. mActionBar.addTab(tab);
  131. notifyDataSetChanged();
  132. }
  133. private staticfinal class TabInfo {
  134. private final Class<?> clazz;
  135. private final Bundle bundle;
  136. Fragment fragment;
  137. TabInfo(Class<?> clazz, Bundle bundle) {
  138. this.clazz = clazz;
  139. this.bundle = bundle;
  140. }
  141. }
  142. }
  143. }
package com.xyz.vvv.ViewPager;
import java.util.ArrayList;
import com.xyz.vvv.R;
import android.app.ActionBar;
import android.app.ActionBar.LayoutParams;
import android.app.ActionBar.Tab;
import android.app.ActionBar.TabListener;
import android.app.Activity;
import android.app.Fragment;
import android.app.FragmentTransaction;
import android.content.Context;
import android.os.Bundle;
import android.support.v13.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.LayoutInflater;
import android.view.View;
public class ViewPagerActivity extends Activity {
private ViewPager mViewPager;
private ViewPagerAdapter mAdapter;
private ActionBar mTabBar;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.viewpager_layout);
mViewPager = (ViewPager) findViewById(R.id.viewpager);
mAdapter = new ViewPagerAdapter(this, mViewPager);
mTabBar = getActionBar();
mAdapter.addTab(mTabBar.newTab().setIcon(R.drawable.tab_icon_qworld),
FirstFragment.class, null);
mAdapter.addTab(mTabBar.newTab().setIcon(R.drawable.tab_icon_group),
SecondFragment.class, null);
mAdapter.addTab(mTabBar.newTab().setIcon(R.drawable.tab_icon_friends),
ThreeFragment.class, null);
mAdapter.addTab(mTabBar.newTab().setIcon(R.drawable.tab_icon_recent),
FourFragment.class, null);
}
private View getCustomView() {
return getLayoutInflater().inflate(R.layout.title_panel_layout, null);
}
private static class ViewPagerAdapter extends FragmentPagerAdapter
implements TabListener, OnPageChangeListener {
private Context mContext;
private ActionBar mActionBar = null;
private ViewPager mViewPager = null;
private ArrayList<TabInfo> mTabList = new ArrayList<TabInfo>();
public ViewPagerAdapter(Activity activity, ViewPager viewPager) {
// TODO Auto-generated constructor stub
super(activity.getFragmentManager());
mContext = activity;
mActionBar = activity.getActionBar();
/*
* mActionBar.setCustomView(getCustomView(), new LayoutParams(
* LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
*/
mActionBar.setDisplayOptions(mActionBar.getDisplayOptions()
^ ActionBar.DISPLAY_SHOW_HOME
^ ActionBar.DISPLAY_SHOW_TITLE, ActionBar.DISPLAY_SHOW_HOME
| ActionBar.DISPLAY_SHOW_TITLE);
mActionBar.setDisplayShowHomeEnabled(false);
mActionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
mViewPager = viewPager;
mViewPager.setAdapter(this);
mViewPager.setOnPageChangeListener(this);
}
/** Override OnPageChangeListener start **/
@Override
public void onPageScrollStateChanged(int arg0) {
// TODO Auto-generated method stub
}
@Override
public void onPageScrolled(int position, float positionOffset,
int positionOffsetPixels) {
// TODO Auto-generated method stub
}
@Override
public void onPageSelected(int position) {
// TODO Auto-generated method stub
mActionBar.setSelectedNavigationItem(position);
}
/** Override OnPageChangeListener end **/
/** Override TabListener start **/
@Override
public void onTabSelected(Tab tab, FragmentTransaction ft) {
// TODO Auto-generated method stub
Object tag = tab.getTag();
for (int i = 0; i < mTabList.size(); i++) {
if (mTabList.get(i) == tag) {
mViewPager.setCurrentItem(i);
}
}
}
@Override
public void onTabUnselected(Tab tab, FragmentTransaction ft) {
// TODO Auto-generated method stub
}
@Override
public void onTabReselected(Tab tab, FragmentTransaction ft) {
// TODO Auto-generated method stub
}
/** Override TabListener end **/
/** Override FragmentPagerAdapter start **/
@Override
public Fragment getItem(int position) {
// TODO Auto-generated method stub
TabInfo tab = mTabList.get(position);
if (tab.fragment == null) {
tab.fragment = Fragment.instantiate(mContext,
tab.clazz.getName(), tab.bundle);
}
return tab.fragment;
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return mTabList.size();
}
/** Override FragmentPagerAdapter end **/
private View getCustomView() {
LayoutInflater inflater = (LayoutInflater) mContext
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
return inflater.inflate(R.layout.title_panel_layout, null);
}
public void addTab(Tab tab, Class<?> clazz, Bundle bundle) {
TabInfo tabInfo = new TabInfo(clazz, bundle);
tab.setTag(tabInfo);
tab.setTabListener(this);
mTabList.add(tabInfo);
mActionBar.addTab(tab);
notifyDataSetChanged();
}
private static final class TabInfo {
private final Class<?> clazz;
private final Bundle bundle;
Fragment fragment;
TabInfo(Class<?> clazz, Bundle bundle) {
this.clazz = clazz;
this.bundle = bundle;
}
}
}
}

里面用到的FirstFragment,SecondFragment,ThreeFragment,FourFragment分别继承Fragment,运行效果如下:

第一个就弄里个TextView,复杂的界面开发者任由发挥了,第二个和第四个都是ListView,第三个ExpandableListView,ListView的使用难点就是写适配器咯,本例是继承BaseAdapter的。ExpandableListView需要一个继承BaseExpandableListAdapter的适配器[不会的请看:ExpandableListView用法]。


2.ViewFlipper

ViewFilpper控件是系统自带控件之一,主要为在同一个屏幕间的切换及设置动画效果,且可以自动播放,用法如下:

配置文件:viewflipper_layout.xml

[java] view plain copy print ?
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:xyz="http://schemas.android.com/apk/res/com.xyz.vvv"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent" >
  6. <ViewFlipper
  7. android:id="@+id/viewflipper"
  8. android:layout_width="match_parent"
  9. android:layout_height="match_parent"
  10. android:inAnimation="@anim/slide_in"
  11. android:outAnimation="@anim/slide_out"
  12. android:flipInterval="2000" >
  13. <include layout="@layout/viewflipper_one_layout" />
  14. <include layout="@layout/viewflipper_two_layout" />
  15. <include layout="@layout/viewflipper_three_layout" />
  16. <include layout="@layout/viewflipper_four_layout" />
  17. <include layout="@layout/viewflipper_five_layout" />
  18. </ViewFlipper>
  19. <!--
  20. <com.xyz.vvv.PageControlView
  21. android:id="@+id/viewflipper_indicator"
  22. android:layout_width="fill_parent"
  23. android:layout_height="wrap_content"
  24. android:layout_marginBottom="25dip"
  25. android:gravity="center_horizontal"
  26. android:layout_alignParentBottom="true"
  27. xyz:cell_width="@dimen/indicator_width"
  28. xyz:cell_height="@dimen/indicator_height" />
  29. -->
  30. </RelativeLayout>
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:xyz="http://schemas.android.com/apk/res/com.xyz.vvv"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<ViewFlipper
android:id="@+id/viewflipper"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:inAnimation="@anim/slide_in"
android:outAnimation="@anim/slide_out"
android:flipInterval="2000" >
<include layout="@layout/viewflipper_one_layout" />
<include layout="@layout/viewflipper_two_layout" />
<include layout="@layout/viewflipper_three_layout" />
<include layout="@layout/viewflipper_four_layout" />
<include layout="@layout/viewflipper_five_layout" />
</ViewFlipper>
<!--  
<com.xyz.vvv.PageControlView
android:id="@+id/viewflipper_indicator"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="25dip"
android:gravity="center_horizontal"
android:layout_alignParentBottom="true"
xyz:cell_width="@dimen/indicator_width"
xyz:cell_height="@dimen/indicator_height" />
-->
</RelativeLayout>

被注释的部分是指示器,那五个layout里都是一个ImageView,本例图片中画有指示器,PageControlView就不需要啦。

android:autoStart="true" <<==>> mViewFlipper.startFlipping(); //自动播放

android:flipInterval="2000" <<==>>mViewFlipper.setFilpInterval(2000); //设置View之间切换的时间间隔

android:inAnimation="@anim/slide_in", android:outAnimation="@anim/slide_out" 对应方法:mViewFlipper.setInAnimation,

mViewFlipper.setOutAnimation。

源文件:ViewFlipperActivity.java

[java] view plain copy print ?
  1. package com.xyz.vvv.ViewFlipper;
  2. import com.xyz.vvv.R;
  3. import android.app.Activity;
  4. import android.os.Bundle;
  5. import android.view.GestureDetector;
  6. import android.view.GestureDetector.OnGestureListener;
  7. import android.view.MotionEvent;
  8. import android.view.View;
  9. import android.view.View.OnTouchListener;
  10. import android.widget.ViewFlipper;
  11. public class ViewFlipperActivityextends Activity implements OnGestureListener,
  12. OnTouchListener {
  13. private ViewFlipper mViewFlipper;
  14. private GestureDetector mGestureDetector;
  15. @Override
  16. protected void onCreate(Bundle savedInstanceState) {
  17. // TODO Auto-generated method stub
  18. super.onCreate(savedInstanceState);
  19. setContentView(R.layout.viewflipper_layout);
  20. mGestureDetector = new GestureDetector(this);
  21. mViewFlipper = (ViewFlipper) findViewById(R.id.viewflipper);
  22. mViewFlipper.setOnTouchListener(this);
  23. mViewFlipper.startFlipping();
  24. }
  25. @Override
  26. public boolean onDown(MotionEvent e) {
  27. // TODO Auto-generated method stub
  28. return false;
  29. }
  30. @Override
  31. public void onShowPress(MotionEvent e) {
  32. // TODO Auto-generated method stub
  33. }
  34. @Override
  35. public boolean onSingleTapUp(MotionEvent e) {
  36. // TODO Auto-generated method stub
  37. return false;
  38. }
  39. @Override
  40. public boolean onScroll(MotionEvent e1, MotionEvent e2,float distanceX,
  41. float distanceY) {
  42. // TODO Auto-generated method stub
  43. return false;
  44. }
  45. @Override
  46. public void onLongPress(MotionEvent e) {
  47. // TODO Auto-generated method stub
  48. }
  49. @Override
  50. public boolean onFling(MotionEvent e1, MotionEvent e2,float velocityX,
  51. float velocityY) {
  52. // TODO Auto-generated method stub
  53. if (e2.getX() - e1.getX() >0) {
  54. //mViewFlipper.showPrevious();
  55. } else {
  56. //mViewFlipper.showNext();
  57. }
  58. return true;
  59. }
  60. @Override
  61. public boolean onTouch(View v, MotionEvent event) {
  62. // TODO Auto-generated method stub
  63. mGestureDetector.onTouchEvent(event);
  64. return true;
  65. }
  66. }
package com.xyz.vvv.ViewFlipper;
import com.xyz.vvv.R;
import android.app.Activity;
import android.os.Bundle;
import android.view.GestureDetector;
import android.view.GestureDetector.OnGestureListener;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.widget.ViewFlipper;
public class ViewFlipperActivity extends Activity implements OnGestureListener,
OnTouchListener {
private ViewFlipper mViewFlipper;
private GestureDetector mGestureDetector;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.viewflipper_layout);
mGestureDetector = new GestureDetector(this);
mViewFlipper = (ViewFlipper) findViewById(R.id.viewflipper);
mViewFlipper.setOnTouchListener(this);
mViewFlipper.startFlipping();
}
@Override
public boolean onDown(MotionEvent e) {
// TODO Auto-generated method stub
return false;
}
@Override
public void onShowPress(MotionEvent e) {
// TODO Auto-generated method stub
}
@Override
public boolean onSingleTapUp(MotionEvent e) {
// TODO Auto-generated method stub
return false;
}
@Override
public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,
float distanceY) {
// TODO Auto-generated method stub
return false;
}
@Override
public void onLongPress(MotionEvent e) {
// TODO Auto-generated method stub
}
@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
float velocityY) {
// TODO Auto-generated method stub
if (e2.getX() - e1.getX() > 0) {
//mViewFlipper.showPrevious();
} else {
//mViewFlipper.showNext();
}
return true;
}
@Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
mGestureDetector.onTouchEvent(event);
return true;
}
}

效果图如下:

图片太宽了,还有一张没加进来(图片来自手机QQ)。

这是ViewFlipper静态加载View,动态加载View请看:ViewFlipper动态加载View

3.ViewFlow

Viewflow 是 Android 平台上一个视图切换的效果库,非标准的得自己下载。ViewFlow 相当于 Android UI 部件提供水平滚动的 ViewGroup,使用 Adapter 进行条目绑定。这个拿来主义 ^-^

按图说话吧: 带圆点的指示器。

配置文件:circle_viewflow_layout.xml

[java] view plain copy print ?
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:xyz="http://schemas.android.com/apk/res/com.xyz.vvv"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. android:orientation="vertical" >
  7. <org.taptwo.android.widget.ViewFlow
  8. android:id="@+id/viewflow"
  9. android:layout_width="fill_parent"
  10. android:layout_height="fill_parent"
  11. xyz:sidebuffer="3" >
  12. </org.taptwo.android.widget.ViewFlow>
  13. <org.taptwo.android.widget.CircleFlowIndicator
  14. android:id="@+id/viewflowindic"
  15. android:layout_width="wrap_content"
  16. android:layout_height="wrap_content"
  17. android:layout_gravity="bottom|center_horizontal"
  18. android:padding="10dip"
  19. android:layout_marginBottom="10dip"
  20. xyz:fadeOut="1000"
  21. xyz:inactiveType="stroke" />
  22. </FrameLayout>
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:xyz="http://schemas.android.com/apk/res/com.xyz.vvv"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<org.taptwo.android.widget.ViewFlow
android:id="@+id/viewflow"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
xyz:sidebuffer="3" >
</org.taptwo.android.widget.ViewFlow>
<org.taptwo.android.widget.CircleFlowIndicator
android:id="@+id/viewflowindic"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="bottom|center_horizontal"
android:padding="10dip"
android:layout_marginBottom="10dip"
xyz:fadeOut="1000"
xyz:inactiveType="stroke" />
</FrameLayout>

源文件:CircleViewFlowActivity.java

[java] view plain copy print ?
  1. package com.xyz.vvv.ViewFlow;
  2. import org.taptwo.android.widget.CircleFlowIndicator;
  3. import org.taptwo.android.widget.ViewFlow;
  4. import com.xyz.vvv.R;
  5. import android.app.Activity;
  6. import android.content.Context;
  7. import android.content.res.Configuration;
  8. import android.os.Bundle;
  9. import android.view.LayoutInflater;
  10. import android.view.View;
  11. import android.view.ViewGroup;
  12. import android.widget.BaseAdapter;
  13. import android.widget.ImageView;
  14. public class CircleViewFlowActivityextends Activity {
  15. private ViewFlow mViewFlow;
  16. private CircleFlowIndicator mIndicator =null;
  17. /** Called when the activity is first created. */
  18. @Override
  19. public void onCreate(Bundle savedInstanceState) {
  20. super.onCreate(savedInstanceState);
  21. setTitle(R.string.circle_title);
  22. setContentView(R.layout.circle_viewflow_layout);
  23. mViewFlow = (ViewFlow) findViewById(R.id.viewflow);
  24. mViewFlow.setAdapter(new ViewFlowAdapter(this),0);
  25. mIndicator = (CircleFlowIndicator) findViewById(R.id.viewflowindic);
  26. mViewFlow.setFlowIndicator(mIndicator);
  27. }
  28. @Override
  29. public void onConfigurationChanged(Configuration newConfig) {
  30. super.onConfigurationChanged(newConfig);
  31. mViewFlow.onConfigurationChanged(newConfig);
  32. }
  33. private class ViewFlowAdapterextends BaseAdapter {
  34. private Context mContext;
  35. private LayoutInflater mInflater =null;
  36. private finalint[] mImageIds = { R.drawable.cupcake, R.drawable.donut,
  37. R.drawable.eclair, R.drawable.froyo, R.drawable.gingerbread,
  38. R.drawable.honeycomb, R.drawable.icecream };
  39. public ViewFlowAdapter(Context ctx) {
  40. mContext = ctx;
  41. mInflater = (LayoutInflater) mContext
  42. .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  43. }
  44. @Override
  45. public int getCount() {
  46. // TODO Auto-generated method stub
  47. return mImageIds.length;
  48. }
  49. @Override
  50. public Integer getItem(int position) {
  51. // TODO Auto-generated method stub
  52. return mImageIds[position];
  53. }
  54. @Override
  55. public long getItemId(int position) {
  56. // TODO Auto-generated method stub
  57. return position;
  58. }
  59. @Override
  60. public View getView(int position, View convertView, ViewGroup parent) {
  61. // TODO Auto-generated method stub
  62. if (convertView ==null) {
  63. convertView = mInflater.inflate(R.layout.circle_viewflow_item_layout,
  64. null);
  65. }
  66. ((ImageView) convertView.findViewById(R.id.img_view))
  67. .setImageResource(getItem(position));
  68. return convertView;
  69. }
  70. }
  71. }
package com.xyz.vvv.ViewFlow;
import org.taptwo.android.widget.CircleFlowIndicator;
import org.taptwo.android.widget.ViewFlow;
import com.xyz.vvv.R;
import android.app.Activity;
import android.content.Context;
import android.content.res.Configuration;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
public class CircleViewFlowActivity extends Activity {
private ViewFlow mViewFlow;
private CircleFlowIndicator mIndicator = null;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setTitle(R.string.circle_title);
setContentView(R.layout.circle_viewflow_layout);
mViewFlow = (ViewFlow) findViewById(R.id.viewflow);
mViewFlow.setAdapter(new ViewFlowAdapter(this), 0);
mIndicator = (CircleFlowIndicator) findViewById(R.id.viewflowindic);
mViewFlow.setFlowIndicator(mIndicator);
}
@Override
public void onConfigurationChanged(Configuration newConfig) {
super.onConfigurationChanged(newConfig);
mViewFlow.onConfigurationChanged(newConfig);
}
private class ViewFlowAdapter extends BaseAdapter {
private Context mContext;
private LayoutInflater mInflater = null;
private final int[] mImageIds = { R.drawable.cupcake, R.drawable.donut,
R.drawable.eclair, R.drawable.froyo, R.drawable.gingerbread,
R.drawable.honeycomb, R.drawable.icecream };
public ViewFlowAdapter(Context ctx) {
mContext = ctx;
mInflater = (LayoutInflater) mContext
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return mImageIds.length;
}
@Override
public Integer getItem(int position) {
// TODO Auto-generated method stub
return mImageIds[position];
}
@Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
// TODO Auto-generated method stub
if (convertView == null) {
convertView = mInflater.inflate(R.layout.circle_viewflow_item_layout,
null);
}
((ImageView) convertView.findViewById(R.id.img_view))
.setImageResource(getItem(position));
return convertView;
}
}
}

ViewFlow还有其他几个例子,个人觉得用的不多,就不贴啦,感兴趣的可以下载下来研究下。

源码下载:http://download.csdn.net/detail/stilo2012/4886363

~~完~~

这篇关于android ViewPager 实现QQ主界面,附带ViewFlipper,ViewFlow用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/679638

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现