android-Viewpager
ViewPager是google SDk中自带的一个附加包的一个类(在android-compatibility这个文件夹下),可以用来实现屏幕间的切换。
如可以仿一个workspace的效果。
Actviity:
- import com.viewpagerindicator.CirclePageIndicator;
- import android.os.Bundle;
- import android.support.v4.app.FragmentActivity;
- import android.support.v4.view.ViewPager;
- public class ViewpagerActivity extends FragmentActivity {
- TestFragmentAdapter mAdapter;
- ViewPager mPager;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- //The look of this sample is set via a style in the manifest
- setContentView(R.layout.simple_circles);
- mAdapter = new TestFragmentAdapter(getSupportFragmentManager());
- mPager = (ViewPager)findViewById(R.id.pager);
- mPager.setAdapter(mAdapter);
- CirclePageIndicator indicator = (CirclePageIndicator)findViewById(R.id.indicator);
- indicator.setViewPager(mPager);
- }
- }
simple_circles.xml:
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout
- xmlns:android="http://schemas.android.com/apk/res/android"
- android:orientation="vertical"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent">
- <android.support.v4.view.ViewPager
- android:id="@+id/pager"
- android:layout_width="fill_parent"
- android:layout_height="0dp"
- android:layout_weight="1"
- />
- <com.viewpagerindicator.CirclePageIndicator
- android:id="@+id/indicator"
- android:padding="10dip"
- android:layout_height="wrap_content"
- android:layout_width="fill_parent"
- />
- </LinearLayout>
TestFragmentAdapter:
- import android.support.v4.app.Fragment;
- import android.support.v4.app.FragmentManager;
- import android.support.v4.app.FragmentPagerAdapter;
- class TestFragmentAdapter extends FragmentPagerAdapter {
- protected static final String[] CONTENT = new String[] { "第一页", "第二页", "第三页", "第四页", };
- private int mCount = CONTENT.length;
- public TestFragmentAdapter(FragmentManager fm) {
- super(fm);
- }
- @Override
- public Fragment getItem(int position) {
- return TestFragment.newInstance(CONTENT[position % CONTENT.length]);
- }
- @Override
- public int getCount() {
- return mCount;
- }
- public void setCount(int count) {
- if (count > 0 && count <= 10) {
- mCount = count;
- notifyDataSetChanged();
- }
- }
- }
TestFragment:
- package com.shao.pager;
- import android.os.Bundle;
- import android.support.v4.app.Fragment;
- import android.view.Gravity;
- import android.view.LayoutInflater;
- import android.view.View;
- import android.view.ViewGroup;
- import android.widget.LinearLayout;
- import android.widget.LinearLayout.LayoutParams;
- import android.widget.TextView;
- public final class TestFragment extends Fragment {
- private static final String KEY_CONTENT = "TestFragment:Content";
- public static TestFragment newInstance(String content) {
- TestFragment fragment = new TestFragment();
- fragment.mContent = content;
- return fragment;
- }
- private String mContent = "???";
- @Override
- public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
- if ((savedInstanceState != null) && savedInstanceState.containsKey(KEY_CONTENT)) {
- mContent = savedInstanceState.getString(KEY_CONTENT);
- }
- TextView text = new TextView(getActivity());
- text.setGravity(Gravity.CENTER);
- text.setText(mContent);
- text.setTextSize(20 * getResources().getDisplayMetrics().density);
- text.setPadding(20, 20, 20, 20);
- LinearLayout layout = new LinearLayout(getActivity());
- layout.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
- layout.setGravity(Gravity.CENTER);
- layout.addView(text);
- return layout;
- }
- @Override
- public void onSaveInstanceState(Bundle outState) {
- super.onSaveInstanceState(outState);
- outState.putString(KEY_CONTENT, mContent);
- }
- }
PageIndicator:
- package com.viewpagerindicator;
- import android.support.v4.view.ViewPager;
- public interface PageIndicator extends ViewPager.OnPageChangeListener {
- public void setViewPager(ViewPager view);
- public void setViewPager(ViewPager view, int initialPosition);
- public void setCurrentItem(int item);
- public void setOnPageChangeListener(ViewPager.OnPageChangeListener listener);
- }
CliclePageIndicator:
- package com.viewpagerindicator;
- import android.content.Context;
- import android.content.res.Resources;
- import android.content.res.TypedArray;
- import android.graphics.Canvas;
- import android.graphics.Paint;
- import android.graphics.Paint.Style;
- import android.os.Parcel;
- import android.os.Parcelable;
- import android.support.v4.view.ViewPager;
- import android.util.AttributeSet;
- import android.view.MotionEvent;
- import android.view.View;
- import com.shao.pager.R;
- public class CirclePageIndicator extends View implements PageIndicator {
- public static final int HORIZONTAL = 0;
- public static final int VERTICAL = 1;
- private float mRadius;
- private final Paint mPaintStroke;
- private final Paint mPaintFill;
- private ViewPager mViewPager;
- private ViewPager.OnPageChangeListener mListener;
- private int mCurrentPage;
- private int mSnapPage;
- private int mCurrentOffset;
- private int mScrollState;
- private int mPageSize;
- private int mOrientation;
- private boolean mCentered;
- private boolean mSnap;
- public CirclePageIndicator(Context context) {
- this(context, null);
- }
- public CirclePageIndicator(Context context, AttributeSet attrs) {
- this(context, attrs, R.attr.circlePageIndicatorStyle);
- }
- public CirclePageIndicator(Context context, AttributeSet attrs, int defStyle) {
- super(context, attrs, defStyle);
- //Load defaults from resources
- final Resources res = getResources();
- final int defaultFillColor = res.getColor(R.color.default_circle_indicator_fill_color);
- final int defaultOrientation = res.getInteger(R.integer.default_circle_indicator_orientation);
- final int defaultStrokeColor = res.getColor(R.color.default_circle_indicator_stroke_color);
- final float defaultStrokeWidth = res.getDimension(R.dimen.default_circle_indicator_stroke_width);
- final float defaultRadius = res.getDimension(R.dimen.default_circle_indicator_radius);
- final boolean defaultCentered = res.getBoolean(R.bool.default_circle_indicator_centered);
- final boolean defaultSnap = res.getBoolean(R.bool.default_circle_indicator_snap);
- //Retrieve styles attributes
- TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.CirclePageIndicator, defStyle, R.style.Widget_CirclePageIndicator);
- mCentered = a.getBoolean(R.styleable.CirclePageIndicator_centered, defaultCentered);
- mOrientation = a.getInt(R.styleable.CirclePageIndicator_orientation, defaultOrientation);
- mPaintStroke = new Paint(Paint.ANTI_ALIAS_FLAG);
- mPaintStroke.setStyle(Style.STROKE);
- mPaintStroke.setColor(a.getColor(R.styleable.CirclePageIndicator_strokeColor, defaultStrokeColor));
- mPaintStroke.setStrokeWidth(a.getDimension(R.styleable.CirclePageIndicator_strokeWidth, defaultStrokeWidth));
- mPaintFill = new Paint(Paint.ANTI_ALIAS_FLAG);
- mPaintFill.setStyle(Style.FILL);
- mPaintFill.setColor(a.getColor(R.styleable.CirclePageIndicator_fillColor, defaultFillColor));
- mRadius = a.getDimension(R.styleable.CirclePageIndicator_radius, defaultRadius);
- mSnap = a.getBoolean(R.styleable.CirclePageIndicator_snap, defaultSnap);
- a.recycle();
- }
- public void setCentered(boolean centered) {
- mCentered = centered;
- invalidate();
- }
- public boolean isCentered() {
- return mCentered;
- }
- public void setFillColor(int fillColor) {
- mPaintFill.setColor(fillColor);
- invalidate();
- }
- public int getFillColor() {
- return mPaintFill.getColor();
- }
- public void setOrientation(int orientation) {
- switch (orientation) {
- case HORIZONTAL:
- case VERTICAL:
- mOrientation = orientation;
- updatePageSize();
- requestLayout();
- break;
- default:
- throw new IllegalArgumentException("Orientation must be either HORIZONTAL or VERTICAL.");
- }
- }
- public int getOrientation() {
- return mOrientation;
- }
- public void setStrokeColor(int strokeColor) {
- mPaintStroke.setColor(strokeColor);
- invalidate();
- }
- public int getStrokeColor() {
- return mPaintStroke.getColor();
- }
- public void setStrokeWidth(float strokeWidth) {
- mPaintStroke.setStrokeWidth(strokeWidth);
- invalidate();
- }
- public float getStrokeWidth() {
- return mPaintStroke.getStrokeWidth();
- }
- public void setRadius(float radius) {
- mRadius = radius;
- invalidate();
- }
- public float getRadius() {
- return mRadius;
- }
- public void setSnap(boolean snap) {
- mSnap = snap;
- invalidate();
- }
- public boolean isSnap() {
- return mSnap;
- }
- /*
- * (non-Javadoc)
- *
- * @see android.view.View#onDraw(android.graphics.Canvas)
- */
- @Override
- protected void onDraw(Canvas canvas) {
- super.onDraw(canvas);
- int longSize;
- int longPaddingBefore;
- int longPaddingAfter;
- int shortPaddingBefore;
- if (mOrientation == HORIZONTAL) {
- longSize = getWidth();
- longPaddingBefore = getPaddingLeft();
- longPaddingAfter = getPaddingRight();
- shortPaddingBefore = getPaddingTop();
- } else {
- longSize = getHeight();
- longPaddingBefore = getPaddingTop();
- longPaddingAfter = getPaddingBottom();
- shortPaddingBefore = getPaddingLeft();
- }
- final int count = mViewPager.getAdapter().getCount();
- final float threeRadius = mRadius * 3;
- final float shortOffset = shortPaddingBefore + mRadius;
- float longOffset = longPaddingBefore + mRadius;
- if (mCentered) {
- longOffset += ((longSize - longPaddingBefore - longPaddingAfter) / 2.0f) - ((count * threeRadius) / 2.0f);
- }
- float dX;
- float dY;
- //Draw stroked circles
- for (int iLoop = 0; iLoop < count; iLoop++) {
- float drawLong = longOffset + (iLoop * threeRadius);
- if (mOrientation == HORIZONTAL) {
- dX = drawLong;
- dY = shortOffset;
- } else {
- dX = shortOffset;
- dY = drawLong;
- }
- canvas.drawCircle(dX, dY, mRadius, mPaintStroke);
- }
- //Draw the filled circle according to the current scroll
- float cx = (mSnap ? mSnapPage : mCurrentPage) * threeRadius;
- if (!mSnap && (mPageSize != 0)) {
- cx += (mCurrentOffset * 1.0f / mPageSize) * threeRadius;
- }
- if (mOrientation == HORIZONTAL) {
- dX = longOffset + cx;
- dY = shortOffset;
- } else {
- dX = shortOffset;
- dY = longOffset + cx;
- }
- canvas.drawCircle(dX, dY, mRadius, mPaintFill);
- }
- @Override
- public boolean onTouchEvent(MotionEvent event) {
- if (event.getAction() == MotionEvent.ACTION_DOWN) {
- final int count = mViewPager.getAdapter().getCount();
- final int longSize = (mOrientation == HORIZONTAL) ? getWidth() : getHeight();
- final float halfLongSize = longSize / 2;
- final float halfCircleLongSize = (count * 3 * mRadius) / 2;
- final float pointerValue = (mOrientation == HORIZONTAL) ? event.getX() : event.getY();
- if ((mCurrentPage > 0) && (pointerValue < halfLongSize - halfCircleLongSize)) {
- setCurrentItem(mCurrentPage - 1);
- return true;
- } else if ((mCurrentPage < count - 1) && (pointerValue > halfLongSize + halfCircleLongSize)) {
- setCurrentItem(mCurrentPage + 1);
- return true;
- }
- }
- return super.onTouchEvent(event);
- }
- @Override
- public void setViewPager(ViewPager view) {
- if (view.getAdapter() == null) {
- throw new IllegalStateException("ViewPager does not have adapter instance.");
- }
- mViewPager = view;
- mViewPager.setOnPageChangeListener(this);
- updatePageSize();
- invalidate();
- }
- private void updatePageSize() {
- if (mViewPager != null) {
- mPageSize = (mOrientation == HORIZONTAL) ? mViewPager.getWidth() : mViewPager.getHeight();
- }
- }
- @Override
- public void setViewPager(ViewPager view, int initialPosition) {
- setViewPager(view);
- setCurrentItem(initialPosition);
- }
- @Override
- public void setCurrentItem(int item) {
- if (mViewPager == null) {
- throw new IllegalStateException("ViewPager has not been bound.");
- }
- mViewPager.setCurrentItem(item);
- mCurrentPage = item;
- invalidate();
- }
- @Override
- public void onPageScrollStateChanged(int state) {
- mScrollState = state;
- if (mListener != null) {
- mListener.onPageScrollStateChanged(state);
- }
- }
- @Override
- public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
- mCurrentPage = position;
- mCurrentOffset = positionOffsetPixels;
- updatePageSize();
- invalidate();
- if (mListener != null) {
- mListener.onPageScrolled(position, positionOffset, positionOffsetPixels);
- }
- }
- @Override
- public void onPageSelected(int position) {
- if (mSnap || mScrollState == ViewPager.SCROLL_STATE_IDLE) {
- mCurrentPage = position;
- mSnapPage = position;
- invalidate();
- }
- if (mListener != null) {
- mListener.onPageSelected(position);
- }
- }
- @Override
- public void setOnPageChangeListener(ViewPager.OnPageChangeListener listener) {
- mListener = listener;
- }
- @Override
- protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
- if (mOrientation == HORIZONTAL) {
- setMeasuredDimension(measureLong(widthMeasureSpec), measureShort(heightMeasureSpec));
- } else {
- setMeasuredDimension(measureShort(widthMeasureSpec), measureLong(heightMeasureSpec));
- }
- }
- /**
- * Determines the width of this view
- *
- * @param measureSpec
- * A measureSpec packed into an int
- * @return The width of the view, honoring constraints from measureSpec
- */
- private int measureLong(int measureSpec) {
- int result = 0;
- int specMode = MeasureSpec.getMode(measureSpec);
- int specSize = MeasureSpec.getSize(measureSpec);
- if (specMode == MeasureSpec.EXACTLY) {
- //We were told how big to be
- result = specSize;
- } else {
- //Calculate the width according the views count
- final int count = mViewPager.getAdapter().getCount();
- result = (int)(getPaddingLeft() + getPaddingRight()
- + (count * 2 * mRadius) + (count - 1) * mRadius + 1);
- //Respect AT_MOST value if that was what is called for by measureSpec
- if (specMode == MeasureSpec.AT_MOST) {
- result = Math.min(result, specSize);
- }
- }
- return result;
- }
- private int measureShort(int measureSpec) {
- int result = 0;
- int specMode = MeasureSpec.getMode(measureSpec);
- int specSize = MeasureSpec.getSize(measureSpec);
- if (specMode == MeasureSpec.EXACTLY) {
- //We were told how big to be
- result = specSize;
- } else {
- //Measure the height
- result = (int)(2 * mRadius + getPaddingTop() + getPaddingBottom() + 1);
- //Respect AT_MOST value if that was what is called for by measureSpec
- if (specMode == MeasureSpec.AT_MOST) {
- result = Math.min(result, specSize);
- }
- }
- return result;
- }
- @Override
- public void onRestoreInstanceState(Parcelable state) {
- SavedState savedState = (SavedState)state;
- super.onRestoreInstanceState(savedState.getSuperState());
- mCurrentPage = savedState.currentPage;
- mSnapPage = savedState.currentPage;
- requestLayout();
- }
- @Override
- public Parcelable onSaveInstanceState() {
- Parcelable superState = super.onSaveInstanceState();
- SavedState savedState = new SavedState(superState);
- savedState.currentPage = mCurrentPage;
- return savedState;
- }
- static class SavedState extends BaseSavedState {
- int currentPage;
- public SavedState(Parcelable superState) {
- super(superState);
- }
- private SavedState(Parcel in) {
- super(in);
- currentPage = in.readInt();
- }
- @Override
- public void writeToParcel(Parcel dest, int flags) {
- super.writeToParcel(dest, flags);
- dest.writeInt(currentPage);
- }
- public static final Parcelable.Creator<SavedState> CREATOR = new Parcelable.Creator<SavedState>() {
- @Override
- public SavedState createFromParcel(Parcel in) {
- return new SavedState(in);
- }
- @Override
- public SavedState[] newArray(int size) {
- return new SavedState[size];
- }
- };
- }
- }
代码下载http://download.csdn.net/detail/shaojie519/4256481
android-Viewpager相关推荐
- android viewpager 嵌套fragment,Android ViewPager+Fragment多层嵌套(使用问题处理)
之前写了Android ViewPager+Fragment(使用问题处理),封装了一个BaseFragment,对于简单使用ViewPager+Fragment而言,是没有问题的. 不过,ViewP ...
- Android -- ViewPager切换动画,PageTransformer
transformPage(View view, float position) view就是滑动中的那个view,position这里是float类型,是当前滑动状态的一个表示,比如当滑动到正全屏时 ...
- android开发实例之viewpager无限循环+自动滚动,Android ViewPager实现无限循环的实例...
Android ViewPager实现无限循环的实例 ViewPager自身并不支持左右无限循环的功能,这里就提供一种方案让Android ViewPager实现左右无限循环的功能,这里记录下: 用于 ...
- android viewpager动态加载页面,Android viewpager中动态添加view并实现伪无限循环的方法...
本文实例讲述了Android viewpager中动态添加view并实现伪无限循环的方法.分享给大家供大家参考,具体如下: viewpager的使用,大家都熟悉,它可以实现页面之间左右滑动的切换,这里 ...
- android ViewPager 实现点击小圆点切换页面 案例
android ViewPager 实现点击小圆点切换页面 说明:在viewpager中,通过左右滑动可以切换页面,同样可以通过点击所指示的小圆点来滑动到某个页面页面. 具体实现方法如下: 主要ac ...
- Android ViewPager 重复数据问题的解决方法
Android ViewPager 重复数据问题的解决方法 参考文章: (1)Android ViewPager 重复数据问题的解决方法 (2)https://www.cnblogs.com/Linc ...
- Android ViewPager示例教程
ViewPager in Android allows the user to flip left and right through pages of data. In our android Vi ...
- android ViewPager轮播制作成品——轮播制作(六)
android ViewPager轮播制作成品--轮播制作(六) 本文主要参考文章:Android 使用ViewPager实现左右循环滑动图片 下面整体介绍一下本系列文章.目的是想要做一个广告.通知轮 ...
- android小圆点滑动切换,android ViewPager 实现点击小圆点切换页面 案例
android ViewPager 实现点击小圆点切换页面 说明:在viewpager中,通过左右滑动可以切换页面,同样可以通过点击所指示的小圆点来滑动到某个页面页面. 具体实现方法如下: 主要ac ...
- android切换页面上滑动动画,Android ViewPager多页面滑动切换以及动画效果
评论 #28楼[楼主] 2012-06-01 14:27D.Winter @孤寒江雪 我猜 要么在头尾各再加入一个页卡 在页卡切换监听中判断,如果选中了头尾的页卡,就返回到相邻的那个页卡.头尾页卡的界 ...
最新文章
- 2022-2028年中国BOPET薄膜行业市场全景调查及投资前景预测报告
- 【Gstreamer】在虚拟机中无法使用硬件加速:gstreamer1.0-vaapi
- python修改excel数据-python之实现对excel表格数据的修改
- LeetCode-两个结构分别遍历,然后合并
- java 10-4 Scanner方法
- 人脸检测SSD 记录
- 美团点评架构再调整,王兴凭什么同时杠上阿里滴滴饿了么
- 有多么巨大的工作量,要交接一个月?
- 简单WEB登录页面代码实现
- adb shell中的am pm命令
- 农夫山泉 || 到底是如何缔造年140亿销售神话的?
- linux同步clock和date,liunx时钟与同步
- JVM系列之深入理解JVM(三)
- 【饭谈】面试场上的珍珑棋局(PUA之无限打击)
- 对图像作LUT处理是什么意思
- 流量分析(wireshark使用)
- 【TeXstudio】【3】较为完整的论文排版模板与bib文件引用方法
- RTL概念与常用RTL建模
- Java使用IKAnalyzer实现多关键字查询
- html中视频代码字段,Html5通过数据流方式播放视频的实现
热门文章
- 《卓有成效的管理者》——学习心得(五)
- 【Jmeter常用断言组件】
- HTML 修改滚动条样式
- 华为p10和p10plus区别_华为P10与P10 Plus的区别,不仅仅只是大了一圈
- 【有限元分析】在ANSYS经典版中划分网格后,如何查看单元数和节点数
- 在西雅图华盛顿大学 (University of Washington) 就读是怎样一番体验?
- Kyligence 春季论坛成功举办,助力企业构建数字化管理新体系
- 三电平半桥LLC谐振变换器电路仿真 采用频率控制方式 引入一定的移相角度
- Revit 二次开发 获取多段轴网的location
- HFM深入技术学习系列之二--规则