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 从开发技术上翻译为省略效果.故名思议,就是当文本无法显示全部时,用什么效果来显示未显示的部 ...
随机推荐
- vue移动端组件库vux使用小记
1.首先安装vux:npm install vux 2.安装vux-loader:npm install vux-loader 3.确认是否已安装less-loader:npm install ...
- Node.js 加密
稳定性: 2 - 不稳定; 正在讨论未来版本的 API 改进,会尽量减少重大变化.详见后文. 使用 require('crypto') 来访问这个模块. 加密模块提供了 HTTP 或 HTTPS 连接 ...
- Docker环境 ELK 快速部署
Docker环境 ELK快速部署 环境 Centos 7.4 , Docker version 17.12 Docker至少3GB内存: #内核配置 echo ' vm.max_map_count = ...
- 实体类双向映射进行Json序列化时出现无限循环的解决问题
1.@JsonIgnoreProperties 指定的字段不会被序列化,如下则ExamPaper的directory字段不会被序列化 @OneToMany(mappedBy = "direc ...
- Python教学相关资料
Python教学调查链接 一.专题 1.绘图 如何开始使用Python来画图 Python画图总结 2.科学计算与数据分析 3.可视化 4.网络爬虫 5. 做笔记 Python-Jupyter Not ...
- 用Matlab画直方图
简介 本文介绍如何使用matlab定制自己的直方图. 关键 使用Matlab的 bar() 函数创建柱状图 bar() 画的bin的高度跟数据相关 bar() 数据每一列一个group,有几列数据就画 ...
- 手势监听GestureDetector 案例
以下只做长按和甩出(用户按下朝某一方向甩动手指)案例 OnGestureListener可以查看到更多的手势事件 案例 package com.qf.mobliesafe.activity; impo ...
- 集群技术(三)MySQL集群深度解析
什么是MySQL集群 MySQL集群是一个无共享的(shared-nothing).分布式节点架构的存储方案,其目的是提供容错性和高性能. 数据更新使用读已提交隔离级别(read-committedi ...
- Android反编译(未混淆的apk)
Android反编译(未混淆的apk) 工具 dex2jar 下载地址:我的CSDN 或者 官网 jd-gui 下载地址:我的CSDN 或者 官网 反编译步骤 1. 将APK解压缩,获取classes ...
- Hadoop的RPC通信原理
RPC调用: RPC(remote procedure call)远程过程调用: 不同java进程间的对象方法的调用. 一方称作服务端(server),一方称为客户端(client): server端 ...