仿今日头条/商城商品详情指示器
来源:互联网 发布:学cnc编程 编辑:程序博客网 时间:2024/05/11 17:12
仿今日头条viewpager切换指示器, 商品详情指示器,以及各种很灵活的定制自己需要的样式:
该控件的实现, 引用的是MagicIndicator. 效果图如下:
具体代码效果如下:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <net.lucode.hackware.magicindicator.MagicIndicator android:id="@+id/magic_indicator" android:layout_width="match_parent" android:layout_height="@dimen/dp_40" android:background="@color/bg_view"/> <View style="@style/separator_line" /> <android.support.v4.view.ViewPager android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="match_parent"/> </LinearLayout>
MagicIndicator的使用:
mMagicIndicator = (MagicIndicator)findViewById(R.id.magic_indicator); mViewPager = (ViewPager)findViewById(R.id.view_pager); this.goodsId = getIntent().getStringExtra("goodsId"); this.contents = getIntent().getStringExtra("content"); this.position = getIntent().getIntExtra("position" ,0); fragPagerAdapter = new SPProductDetailInnerTabAdapter(getSupportFragmentManager() , goodsId ,contents); mViewPager.setAdapter(fragPagerAdapter); // 当前页不定位到中间 final CommonNavigator commonNavigator = new CommonNavigator(this); commonNavigator.setAdjustMode(true); commonNavigator.setScrollPivotX(0.15f); commonNavigator.setAdapter(new CommonNavigatorAdapter() { @Override public int getCount() { return mDataList == null ? 0 : mDataList.size(); } @Override public IPagerTitleView getTitleView(Context context, final int index) { SimplePagerTitleView simplePagerTitleView = new SimplePagerTitleView(context); simplePagerTitleView.setText(mDataList.get(index)); simplePagerTitleView.setNormalColor(getResources().getColor(R.color.sub_title)); simplePagerTitleView.setSelectedColor(getResources().getColor(R.color.light_red)); simplePagerTitleView.setTextSize(12); simplePagerTitleView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { mViewPager.setCurrentItem(index); } }); return simplePagerTitleView; } @Override public IPagerIndicator getIndicator(Context context) { LinePagerIndicator indicator = new LinePagerIndicator(context); indicator.setMode(LinePagerIndicator.MODE_WRAP_CONTENT); indicator.setYOffset(UIUtil.dip2px(context, 3)); indicator.setColors(getResources().getColor(R.color.light_red)); return indicator; } }); mMagicIndicator.setNavigator(commonNavigator); mMagicIndicator.setDelegate(new SimpleViewPagerDelegate(mViewPager));
这样就可以快速实现一个tab选项卡式效果, 可以很随意自定义自己的样式.
完整Demo下载地址:Demo下载地址
0 0
- 仿今日头条/商城商品详情指示器
- 仿今日头条的滚动指示器的效果
- Android仿今日头条详情页实现
- 仿今日头条
- 仿今日头条
- 高仿今日头条字体渐变指示器,滑动+点击切换,如丝顺滑
- 仿今日头条最强顶部导航指示器,支持6种模式
- 安卓学习笔记---仿今日头条最强顶部导航指示器,支持6种模式
- 自定义View之仿今日头条颜色渐变指示器导航栏
- viewpagerindacator仿今日头条
- 精仿今日头条
- 精仿今日头条
- 精仿今日头条
- 精仿今日头条
- 精仿今日头条
- 仿今日头条Fragment
- 仿今日头条adapter
- 仿今日头条滑动评论效果
- git 学习笔记
- linux下nutch的安装配置
- 2-sat入门(例题hdu1814,poj3648)持续更新
- android 多尺寸生产xml
- 工具及其对商业社会的影响思考
- 仿今日头条/商城商品详情指示器
- C++拷贝构造函数详解
- ios打包ipa的四种实用方法(.app转.ipa)
- android lk解读 (2)
- 如何将iphone系统由正式版转为beta测试版
- 一步一步教你如何导出JAR包后将多个JAR包合并,并混淆
- JDBC重要的四大对象
- MySQL 常用相关总结
- 待解决poj1426 同余模