`
yunlonglove
  • 浏览: 238958 次
社区版块
存档分类
最新评论

android Viewpager HorizontalScrollView 实现分页栏拖拽

 
阅读更多

首先我们先看一个效果:

前两个是网易的,它做的title不能拖拽,。不过点击动画效果挺不错的,有待学习啊,后面两个是搜狐的,它做的效果不错,(注意看title)可以左右拖拽的,因为比较多嘛。

下面这两个图不错,是多米音乐客户端.它可以来回切换屏幕,(重要的是没有出现向viewpager动画那么恶心状态)这个做的很棒,


现在我做的是viewpager+HorizontalScrollView 实现来回切屏,并且title可以左右拖拽.

代码片段

/***
	 * init view
	 */
	void InItView() {
		pageViews = new ArrayList<View>();
		View view01 = getLocalActivityManager().startActivity("activity01",
				new Intent(this, MainActivity1.class)).getDecorView();
		View view02 = getLocalActivityManager().startActivity("activity02",
				new Intent(this, MainActivity2.class)).getDecorView();
		View view03 = getLocalActivityManager().startActivity("activity02",
				new Intent(this, MainActivity3.class)).getDecorView();
		View view04 = getLocalActivityManager().startActivity("activity03",
				new Intent(this, MainActivity4.class)).getDecorView();
		View view05 = getLocalActivityManager().startActivity("activity04",
				new Intent(this, MainActivity5.class)).getDecorView();
		View view06 = getLocalActivityManager().startActivity("activity05",
				new Intent(this, MainActivity6.class)).getDecorView();
		pageViews.add(view01);
		pageViews.add(view02);
		pageViews.add(view03);
		pageViews.add(view04);
		pageViews.add(view05);
		pageViews.add(view06);
	}
 /***
     * init title
     */
	void InItTitle() {
		int width = getWindowManager().getDefaultDisplay().getWidth() / 5;
		for (int i = 0; i < title.length; i++) {
			RadioButton radioButton = new RadioButton(this, null,
					R.style.radioButton);
			radioButton.setText(title[i]);
			radioButton.setTextSize(17);
			radioButton.setTextColor(com.jj.viewpager.R.color.black);
			radioButton.setWidth(width);
			radioButton.setHeight(height);
			radioButton.setGravity(Gravity.CENTER);
			radioGroup.addView(radioButton);
		}
	}


 /***
     * init title
     */
	void InItTitle1() {
		textViews = new ArrayList<TextView>();
		int width = getWindowManager().getDefaultDisplay().getWidth() / 5;
		int height = 70;
		for (int i = 0; i < title.length; i++) {
			TextView textView = new TextView(this);
			textView.setText(title[i]);
			textView.setTextSize(17);
			textView.setTextColor(com.jj.viewpager.R.color.black);
			textView.setWidth(width);
			textView.setHeight(height - 30);
			textView.setGravity(Gravity.CENTER);
			textView.setId(i);
			textView.setOnClickListener(this);
			textViews.add(textView);
			// 分割线
			View view = new View(this);
			LinearLayout.LayoutParams layoutParams = new LayoutParams(
					LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
			layoutParams.width = 1;
			layoutParams.height = height - 40;
			layoutParams.gravity = Gravity.CENTER;
			view.setLayoutParams(layoutParams);
			view.setBackgroundColor(com.jj.viewpager.R.color.gray);
			linearLayout.addView(textView);
			if (i != title.length - 1) {
				linearLayout.addView(view);
			}

		}
	}

/***
	 * 选中效果
	 */
	public void setSelector(int id) {
		for (int i = 0; i < title.length; i++) {
			if (id == i) {
				Bitmap bitmap = BitmapFactory.decodeResource(getResources(),
						R.drawable.grouplist_item_bg_normal);
				textViews.get(id).setBackgroundDrawable(
						new BitmapDrawable(bitmap));
				textViews.get(id).setTextColor(Color.RED);
				viewPager.setCurrentItem(i);
			}

			else {
				textViews.get(i).setBackgroundDrawable(new BitmapDrawable());
				textViews.get(i).setTextColor(com.jj.viewpager.R.color.black);
			}
		}
	}

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		linearLayout = (LinearLayout) findViewById(R.id.ll_main);
		viewPager = (ViewPager) findViewById(R.id.pager);
		horizontalScrollView = (HorizontalScrollView) findViewById(R.id.horizontalScrollView);
		InItTitle1();
		setSelector(0);
		InItView();
		viewPager.setAdapter(new myPagerView());
		viewPager.clearAnimation();
		viewPager.setOnPageChangeListener(new OnPageChangeListener() {

			@Override
			public void onPageSelected(int arg0) {
				setSelector(arg0);
			}

			@Override
			public void onPageScrolled(int arg0, float arg1, int arg2) {

			}

			@Override
			public void onPageScrollStateChanged(int arg0) {

			}
		});
	}

	@Override
	public void onClick(View v) {
		setSelector(v.getId());
	}

	class myPagerView extends PagerAdapter {
		// 显示数目
		@Override
		public int getCount() {
			return pageViews.size();
		}

		@Override
		public boolean isViewFromObject(View arg0, Object arg1) {
			return arg0 == arg1;
		}

		@Override
		public int getItemPosition(Object object) {
			// TODO Auto-generated method stub
			return super.getItemPosition(object);
		}

		@Override
		public void destroyItem(View arg0, int arg1, Object arg2) {
			// TODO Auto-generated method stub
			((ViewPager) arg0).removeView(pageViews.get(arg1));
		}

		/***
		 * 获取每一个item, 类于listview中的getview
		 */
		@Override
		public Object instantiateItem(View arg0, int arg1) {
			((ViewPager) arg0).addView(pageViews.get(arg1));
			return pageViews.get(arg1);
		}

	}

实现起来不难,主要用了HorizontalScrollView 这个实现左右拖拽功能,网上大部分都是用RadioButton实现的,可是觉得有点复杂,我们何不直接对Textview进行控制呢,

样式如下:


主要看title可以来回拖拽,主要是实现这个功能,其实很简单,看上面代码我想你一下就ok了。

现在说一下问题”首先,我们用的是viewpager来实现,滑动的时候效果很不错,可是当我们点击title切换屏幕的时候,效果就难看了,因为viewpager动画的缘故,如果由1屏-6屏,则它会动画经过2,3,4,5,效果是相当的难看,想找个方案禁止动画,可没有找到,如果知道的朋友麻烦告诉下,谢谢在先了。“ 还有就是可以拖拽的标题分页,最好和activitygroup运用.搜狐那个就很不错.实在不行重写viewpaper吧,不过有点复杂,有时间了研究下.这里对viewpager只是简单用一下,不过前面几节都讲过,禁止屏幕滑动和缩回效果等.


源码下载







分享到:
评论

相关推荐

    Android ViewPager联动HorizontalScrollView

    1、首先让导航栏横向滑动:HorizontalScrollView中放RadioGroup,RadioGroup中放RadioButton。 2、底部为ViewPager。 3、通过设置ViewPager的页面改变来设置RadioButton的模拟点击事件。 4、监听RadioButton点击,来...

    导航栏联动效果( HorizontalScrollView+ViewPager)

    在Android开发中,创建动态、交互丰富的用户界面是至关重要的,而"导航栏联动效果(HorizontalScrollView+ViewPager)"正是实现这一目标的一种有效方法。这种技术通常用于电商平台、新闻应用等,提供一种平滑的横向...

    ViewPager+HorizontalScrollView可滑动标题栏demo

    总的来说,结合使用ViewPager和HorizontalScrollView实现滑动标题栏是一种常见且实用的方法,但要创建一个完善的、用户体验良好的解决方案,需要对Android的视图层次、触摸事件处理以及性能优化有深入理解。...

    利用HorizontalScrollView加Viewpager实现多个的导航标题栏

    在Android开发中,创建一个可滚动的多导航标题栏是一个常见的需求,这通常涉及到`HorizontalScrollView`和`ViewPager`的组合使用。`HorizontalScrollView`允许用户在水平方向上滚动视图,而`ViewPager`则用于展示多...

    Android仿ViewPager(重写HorizontalScrollView)

    总之,通过重写HorizontalScrollView,我们可以根据实际需求定制更符合项目特色的视图切换组件,实现类似ViewPager的功能。这是一个锻炼和提升Android开发技能的好方法,同时也能提高应用的用户体验。在实际操作过程...

    ViewPager头用HorizontalScrollView自己实现

    标题 "ViewPager头用HorizontalScrollView自己实现" 涉及到的是Android开发中的一个常见需求,即自定义ViewPager的头部视图。ViewPager是Android SDK中一个强大的控件,用于展示多个可以横向滑动的页面,常用于实现...

    android viewpager各种滑动动画

    在Android开发中,ViewPager是一个非常重要的组件,常用于实现页面滑动切换的效果,例如在应用的引导页、图片轮播或者Tab布局中。本篇将深入讲解如何在ViewPager中实现各种自定义滑动动画,以及如何优化性能并保持...

    ViewPager实现无限分页

    总之,ViewPager是Android平台中实现高效、流畅分页显示的利器,其核心在于复用机制和分页加载策略。通过巧妙的设计和实现,开发者可以创建出无限滚动的效果,同时保持良好的性能和内存管理。在MyApplication2这个...

    android HorizontalScrollView和ViewPager联动效果

    在Android开发中,HorizontalScrollView和ViewPager是两种常用的布局组件,它们各自有特定的功能,并且在某些场景下可以结合使用以实现独特的交互效果。本资源主要探讨了如何将这两个组件联动,尤其是在上下控件间...

    Android应用源码之Android ViewPager Fragment实现选项卡.zip

    在Android开发中,ViewPager是一个非常重要的组件,常用于创建滑动页面效果,特别是在实现选项卡切换功能时。这个压缩包“Android应用源码之Android ViewPager Fragment实现选项卡”提供了具体的示例代码,帮助...

    android ViewPager指示器

    在Android开发中,ViewPager是一种非常常用的组件,它允许用户通过左右滑动来浏览多个页面,常用于实现类似轮播图或者Tab切换的效果。而ViewPager指示器则是与ViewPager配合使用,用以显示当前所选页面的状态,通常...

    Android ViewPager和Fragment 实现滑动切换页面

    在Android应用开发中,`ViewPager`和`Fragment`是两个重要的组件,它们常被结合使用以实现用户界面的滑动切换效果。`ViewPager`提供了一个可以左右滑动查看多个页面的容器,而`Fragment`则作为Activity的部分内容,...

    Android 使用ViewPager实现view轮播效果,单个item分页样式,多个item分页样式,横向listview

    在Android开发中,ViewPager是一种非常常用的组件,常用于实现页面滑动切换的效果,例如在应用启动页、广告轮播或导航栏中。本教程将详细讲解如何使用ViewPager实现view的轮播效果,包括单个item分页样式和多个item...

    Android ViewPager多页面滑动切换以及动画效果

    Android ViewPager实现仿QQ多页面滑动切换以及动画效果

    Android ViewPager切换的七种动画

    Android ViewPager切换的七种动画,分别是:深入浅出,立方体,旋转,左右折叠,右上角进入,右下角进入和淡入淡出。

    Android ViewPager-实现左右两个屏幕的切换-IT计算机-毕业设计.zip

    【Android ViewPager】是Android开发中的一个关键组件,用于在多个视图之间进行平滑的滑动切换,通常用于实现类似“Tab”或者“轮播图”的效果。在本项目"Android ViewPager-实现左右两个屏幕的切换"中,我们将探讨...

    android ViewPager嵌套Fragment动态删除和插入案例

    android ViewPagerr嵌套Fragment 动态删除 动态插入,完美实现动态删除和插入,Fragment懒加载,可适用于各版本。the sample of android viewpager daynmic update or delete

    Android ViewPager实现圆点导航左右滑动和Fragment页面切换

    在Android开发中,`ViewPager` 是一个非常重要的组件,它允许用户通过左右滑动来浏览多个页面,通常用于实现滑动切换的界面效果。在这个示例中,我们结合`ViewPager`、`Fragment`、`PagerAdapter` 和 `...

    android HorizontalScrollView和ViewPager联动效果新样式

    在Android开发中,HorizontalScrollView和ViewPager是两种常用的布局控件,它们各自有着特定的功能和应用场景。HorizontalScrollView允许用户水平滑动查看多个子视图,而ViewPager则常用于实现页面滑动的效果,通常...

    Android ViewPager实现类似广告滚动的效果

    在Android应用开发中,ViewPager是一种常用的组件,它允许用户通过左右滑动来浏览多个页面,非常适合用来实现诸如轮播图、广告展示等效果。在这个场景中,我们将探讨如何利用ViewPager来创建一个类似广告滚动的功能...

Global site tag (gtag.js) - Google Analytics