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

时间: 2024-01-08 03:35:32

Android 纵向跑马灯滚动效果的相关文章

Android中跑马灯既能水平滚动,又能上下滚动。。

问题描述 Android中跑马灯既能水平滚动,又能上下滚动.. 就是有三条数据,三条数据字数比较多,我想利用跑马灯,既能三条数据上下循环滚动,又能每条数据水平滚动,请问这个可以实现吗? 解决方案 水平的用marquee,垂直的用js设置下容器的scrollTop来循环滚动或者反过来也行,反过来容器要设置scrollLeft 解决方案二: HTML里的标签可以实现你的要求 解决方案三: 用marquee,垂直的用js设置下容器的scrollTop来滚动

Android实现跑马灯效果的方法_Android

本文实例讲述了Android实现跑马灯效果的方法.分享给大家供大家参考.具体如下: 运行效果截图如下: 直接在布局里写代码就好了: <TextView android:id="@+id/menu_desc" android:layout_width="300dip" android:layout_height="wrap_content" android:text="温馨提示:左右滑动更改菜单,点击进入" android

Android实现跑马灯效果的方法

本文实例讲述了Android实现跑马灯效果的方法.分享给大家供大家参考.具体如下: 运行效果截图如下: 直接在布局里写代码就好了: <TextView android:id="@+id/menu_desc" android:layout_width="300dip" android:layout_height="wrap_content" android:text="温馨提示:左右滑动更改菜单,点击进入" android

基于jquery的文字向上跑动类似跑马灯的效果_jquery

想实现一个类似跑马灯的效果,发现跑马灯有空格.效果也不美观,于是用jquery写了个 页面代码 <div class="recordList"> <ul class="tpl-rotate-recordList" style="margin-top: 0px;"> <li class="tpl-rotate-recordList-item"> 恭喜187****5204获得1000RBM &

iOS 跑马灯滚动条效果程序代码

跑马灯效果的滚动条,一般出现在ios应用的底部.用于显示动态变化的信息或内容较长的信息,在个类应用中使用广泛 以下两种可用的跑马灯滚动MarqueeBar的实现. 1.直接在ViewController中实现对UIView的位置定时移动来实现,以下代码直接加入到ViewController中,在viewWillAppear中调用loadView即可.    代码如下 复制代码 - (void)marqueeView {       CGRect frame = self.vMarqueeCont

基于jquery的文字向上跑动类似跑马灯的效果

 想实现一个类似跑马灯的效果,发现跑马灯有空格.效果也不美观,于是用jquery写了个 页面代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 <div class="recordList">  <ul class="tpl-rotate-recordList" style="margin-top:

Android TextView实现垂直滚动效果的方法_Android

本文实例讲述了Android TextView实现垂直滚动效果的方法.分享给大家供大家参考,具体如下: 在TextView中,如果文本很长,可能需要实现垂直滚动显示文本的效果.这里需要在XML布局文件中为TextView设置如下几个属性. Android:scrollbars="vertical" android:scrollbarStyle="X" 其中X为outsideOverlay或insideOverlay. android:scrollbarFadeDur

JS实现状态栏跑马灯文字效果代码_javascript技巧

本文实例讲述了JS实现状态栏跑马灯文字效果代码.分享给大家供大家参考,具体如下: 这款状态栏跑马灯,文字跑动的定义在数组内,自己可修改内容.现在的IE8貌似不兼容,有缺憾的代码,欢迎JS爱好者修正,修正请发回一份.状态栏为效果显示区. 运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js/2015/js-ztlpmd-txt-style-codes/ 具体代码如下: <HTML> <HEAD> <TITLE>间隔状态栏跑马灯</T

Android TextView实现垂直滚动效果的方法

本文实例讲述了Android TextView实现垂直滚动效果的方法.分享给大家供大家参考,具体如下: 在TextView中,如果文本很长,可能需要实现垂直滚动显示文本的效果.这里需要在XML布局文件中为TextView设置如下几个属性. Android:scrollbars="vertical" android:scrollbarStyle="X" 其中X为outsideOverlay或insideOverlay. android:scrollbarFadeDur