Android 纵向跑马灯滚动效果
像淘宝和京东都会有跑马灯的效果,今天给大家贡献下以前项目的一个demo,各位看官,且看效果图。
我们先定义一个Bean文件,这个实体类文件主要包含标题,内容描述,以及还有跳转的链接。
LampBean
public class LampBean implements Serializable { public String title; public String info; }
接下来我们要去自定义一个LampView了,Lamp主要实现数据的接受,适配器填充数据,以及滚动实现,这里可以看出适配器模式在我们Android开发模式中用处的广泛,为了方便后面的数据的适配我们将数据源用泛型。
public abstract class BaseAutoScrollTextView<T> extends ListView implements AutoScrollData<T> { private ArrayList<T> mDataList = new ArrayList<T>(); private float mSize=16; private int mMax; private int position = -1; private int scroll_Y; private int mScrollY; private AutoScrollAdapter mAutoScrollAdapter = new AutoScrollAdapter(); private OnItemClickListener mOnItemClickListener; private long mTimer = 1000; private Context mContext; protected abstract int getAdertisementHeight(); private Handler handler = new Handler(); Runnable runnable = new Runnable() { @Override public void run() { // 开启轮播 switchItem(); handler.postDelayed(this, mTimer); } }; public interface OnItemClickListener { public void onItemClick(int position); } public BaseAutoScrollTextView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); this.mContext = context; mScrollY = dip2px(getAdertisementHeight()); init(); } public BaseAutoScrollTextView(Context context, AttributeSet attrs) { this(context, attrs, 0); } public BaseAutoScrollTextView(Context context) { this(context, null); } private void init() { this.setDivider(null); this.setFastScrollEnabled(false); this.setDividerHeight(0); this.setEnabled(false); } private int dip2px(float dipValue) { final float scale = mContext.getResources().getDisplayMetrics().density; return (int) (dipValue * scale + 0.5f); } private void switchItem() { if (position == -1) { scroll_Y = 0; } else { scroll_Y = mScrollY; } smoothScrollBy(scroll_Y, 2000); setSelection(position); position++; } private class AutoScrollAdapter extends BaseAdapter { @Override public int getCount() { final int count = mDataList == null ? 0 : mDataList.size(); return count > 1 ? Integer.MAX_VALUE : count; } @Override public Object getItem(int position) { return mDataList.get(position % mMax); } @Override public long getItemId(int position) { return position % mMax; } @Override public View getView(final int position, View convertView, ViewGroup parent) { ViewHolder viewHolder; if (null == convertView) { viewHolder = new ViewHolder(); convertView = LayoutInflater.from(mContext).inflate( R.layout.item_lamp_layout, null); viewHolder.mTitleView = (TextView) convertView .findViewById(R.id.tv_title); viewHolder.mInfoView = (TextView) convertView .findViewById(R.id.tv_info); convertView.setTag(viewHolder); } else { viewHolder = (ViewHolder) convertView.getTag(); } T data = mDataList.get(position % mMax); initItemData(position, convertView, viewHolder, data); return convertView; } } private void initItemData(final int position, View convertView, ViewHolder viewHolder, T data) { viewHolder.mTitleView .setLayoutParams(new RelativeLayout.LayoutParams( RelativeLayout.LayoutParams.WRAP_CONTENT, dip2px(getAdertisementHeight()))); viewHolder.mTitleView.setTextSize(mSize); viewHolder.mInfoView.setTextSize(mSize); viewHolder.mTitleView.setText(getTextTitle(data)); viewHolder.mInfoView.setText(getTextInfo(data)); convertView.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { mOnItemClickListener.onItemClick(position % mMax); } }); } static class ViewHolder { TextView mTitleView;// 标题 TextView mInfoView;// 内容 } @Override public boolean onInterceptTouchEvent(MotionEvent ev) { return false; } public void setData(ArrayList<T> _datas) { mDataList.clear(); mDataList.addAll(_datas); mMax = mDataList == null ? 0 : mDataList.size(); this.setAdapter(mAutoScrollAdapter); mAutoScrollAdapter.notifyDataSetChanged(); } public void setTextSize(float _size){ this.mSize=_size; } public void setOnItemClickListener(OnItemClickListener _listener) { this.mOnItemClickListener = _listener; } public void setTimer(long _time) { this.mTimer = _time; } public void start() { handler.postDelayed(runnable, 1000); } public void stop() { handler.removeCallbacks(runnable); } }
然后添加一个实现的类:
public class VerticalLampView extends BaseAutoScrollTextView<LampBean> { public VerticalLampView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } public VerticalLampView(Context context, AttributeSet attrs) { super(context, attrs); } public VerticalLampView(Context context) { super(context); } @Override public String getTextTitle(LampBean data) { return data.title; } @Override public String getTextInfo(LampBean data) { return data.info; } /** * 这里面的高度应该和你的xml里设置的高度一致 */ @Override protected int getAdertisementHeight() { return 40; } }
最后是测试代码:
public class LampView extends FrameLayout { @Bind(R.id.lamp_view) VerticalLampView lampView; private Context mContext = null; private List<LampBean> list=new ArrayList<>(); public LampView(Context context, AttributeSet attrs) { super(context, attrs); this.mContext = context; init(); } private void init() { setView(); } private void setView() { inflate(getContext(), R.layout.lamp_layout, this); ButterKnife.bind(this, this); initData(); initView(); } private void initView() { lampView.setData((ArrayList<LampBean>) list); lampView.setTextSize(15); lampView.setTimer(2000); lampView.start(); } private void initData() { LampBean bean = new LampBean(); bean.title = "爆款"; bean.info = "踏青零食上京东,百万零食1元秒"; list.add(bean); bean = new LampBean(); bean.title = "公告"; bean.info = "看老刘中国行,满129减50!"; list.add(bean); bean = new LampBean(); bean.title = "活动"; bean.info = "高姿CC霜全渠道新品首发,领券199减50,点击查看"; list.add(bean); } }
最后老规矩附上代码地址:
http://download.csdn.net/detail/xiangzhihong8/9566472
Android 纵向跑马灯滚动效果的更多相关文章
- 在android中用跑马灯的效果显示textview
大家好,在我们通常的android project中,通常需要用到textview这一个布局文件,并且对于这一个显示布局所需要的文本文字内容. 下面我们就来介绍一种方法来实现在android中用跑马灯 ...
- Android 高级UI设计笔记05:使用TextView实现跑马灯的效果
1. 使用TextView属性实现跑马灯的效果: (1). 新建一个Android工程,命名为"MarqueeTextViewDemo",如下: (2). 来到activity_m ...
- Android:TextView文字跑马灯的效果实现
解决TextView文字显示不全的问题. 简单设置跑马灯的效果: <TextView android:id="@+id/textView" android:layout_wi ...
- android使用TextView实现跑马灯的效果(1)
android使用TextView实现跑马灯的效果 1.activity_main.xml <?xml version="1.0" encoding="utf-8& ...
- android实现跑马灯效果
第一步:新建一个新项目,MarqueeTextView 首先为了观察到跑马灯效果,将要显示的文字极可能 写长.在strings.xml目录里面将 <string name="hello ...
- Android中TextView不获取焦点可以实现跑马灯的效果
之前在网上找了很多关于TextView的跑马灯效果实现的例子,实现起来都存在一些问题,例如一种是完全重画一个跑马灯,还有就是只设置TextView的相关属性使其具有跑马灯的效果,总的来说这两种方法都是 ...
- Android TextView 字数过多,用跑马灯滚动形式实现
上代码: <TextView android:layout_width="120dp" android:layout_height="wrap_content&qu ...
- 它们的定义TextView使之具有跑马灯的效果
一.引入问题 使用通用textview快乐效应,焦点事件不启动滚动,button目前的焦点事件,但丑,因此,需要定制TextView 天生焦点 个textview FocusedTextView.ja ...
- 浅谈TextView Ellipsize效果与Marquee跑马灯无效果问题
说到TextView 效果,相信大家一定熟悉跑马灯. 先来看看 Ellipsize是什么,Ellipsize 从开发技术上翻译为省略效果.故名思议,就是当文本无法显示全部时,用什么效果来显示未显示的部 ...
随机推荐
- ajax跨域请求问题及解决办法总结
1.浏览器的同源策略及规避方法 目前,所有浏览器都实行同源政策.即协议.域名.端口都相同的URI称为"同源".不同源的url之间: a.无法读取cookie.localstorag ...
- Ubuntu 16.04LTS 安装 MATLAB 2014B
环境:Ubuntu 16.04LTS 软件:MATLAB 2014B MATLAB 2014B 下载地址(带Crack): 链接: https://pan.baidu.com/s/1nvGtmEd 密 ...
- iOS开发-文件管理
iOS学习笔记(十七)--文件操作(NSFileManager) 浅析 RunLoop 解决EXC_BAD_ACCESS错误的一种方法--NSZombieEnabled iOS开发--Swift篇&a ...
- RHEL Linux常用指令
查询已安装软件包 rpm -qa|grep * 安装软件 rpm -ivh * 查询Linux版本 uname -a lsb_release -a cat /etc/redhat-release ca ...
- Go 语言数组
Go 语言提供了数组类型的数据结构. 数组是具有相同唯一类型的一组已编号且长度固定的数据项序列,这种类型可以是任意的原始类型例如整形.字符串或者自定义类型. 相对于去声明number0, number ...
- Python教学相关资料
Python教学调查链接 一.专题 1.绘图 如何开始使用Python来画图 Python画图总结 2.科学计算与数据分析 3.可视化 4.网络爬虫 5. 做笔记 Python-Jupyter Not ...
- 【移动开发】targetSdkVersion的作用
在AndroidMenifest.xml中,常常会有下面的语句: <uses-sdk android:minSdkVersion="4" android:targetSdkV ...
- Linux 虚存 linux2.6内核特性
一.大型页面的支持 当代计算机体系结构大都支持多种页面大小,例如,IA-32体系结构支持4KB或4MB的页面, Linux操作系统只是将大型页面用于映射实际的内核映像.大型页面的使用主要是为了改进高性 ...
- malloc_stats---检查内存泄露的神器
在之前的博客中提到过,valgrind可以用来检测内存泄露,但在使用中,往往会遇到一些问题,给调试工作带来很多不必要的麻烦,我自己遇到的有以下两种: (1)内存泄露误检(系统初始化时,可能有一些需要长 ...
- Maven 核心原理
Maven 核心原理 标签 : Java基础 Maven 是每一位Java工程师每天都会接触的工具, 但据我所知其实很多人对Maven理解的并不深, 只把它当做一个依赖管理工具(下载依赖.打包), M ...