我是靠谱客的博主 害怕宝贝,这篇文章主要介绍Android textview和listview实现水平自动滚动的走马灯效果,现在分享给大家,希望可以做个参考。

当我们遇到需要在一个textview里显示较长文字时候,往往有以下几种考虑:

          1.换行,Android里本身也是这样在考虑;

          2.可以进行水平或者垂直滑动;

          3.采用走马灯效果。

          其实这三种要实现都不难,根据实际情况进行选择就是了。不过我在具体实现走马灯时候遇到了一些问题,后来参考了下大神的代码,得以解决,记录一下。

          代码地址是:http://download.csdn.net/download/wds1181977/5997065

          具体情况如下:


          textview里要实现走马灯效果,主要需要三点:

          设置单行显示;设置文本超出textview后的效果;以及最重要的是设置焦点。

          对应代码如下:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
<TextView android:id="@+id/tv_title" android:layout_width="100dp" android:layout_height="match_parent" android:text="基本信息" android:textColor="@color/black" android:gravity="center_vertical" android:scrollHorizontally="true" android:focusable="true" android:focusableInTouchMode="true" android:singleLine="true" android:ellipsize="marquee" android:marqueeRepeatLimit="marquee_forever" />

         focusable和fucosableInTouchMode是配套用来设置获取焦点的;singleLine是设置单行;ellipsize是设置文本过长的效果,其中marquee是走马灯的效果,marqueeRepeatLimit是自动滚动显示多少次,marquee_forver是一直滚动。

         这样写好了以后,但实际我运行的时候并没有出现走马灯的效果,而是显示了最前面部分,然后就是,,,省略掉后面内容了。

         找了一下原因,就是在这个获取焦点上。

         一般情况我们的布局都比demo复杂,静态的设置focusable=true甚至动态的在代码用textview.setfocusable里设置并不能保证焦点就是在这个textview上。

         所以更好的办法是写一个自定义的textview,将焦点写死。比如:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
public class MTextView extends TextView { public MTextView(Context context) { super(context); // TODO Auto-generated constructor stub } public MTextView(Context context, AttributeSet attrs) { super(context, attrs); // TODO Auto-generated constructor stub } @Override public boolean isFocused() { // TODO Auto-generated method stub return true; } }
        然后在代码里 引用:

复制代码
1
2
3
4
5
6
7
8
9
10
11
<com.diit.apppro.presentation.view.component.common.MTextView android:id="@+id/tv_title" android:layout_width="100dp" android:layout_height="match_parent" android:text="基本信息" android:textColor="@color/black" android:gravity="center_vertical" android:scrollHorizontally="true" android:singleLine="true" android:ellipsize="marquee" android:marqueeRepeatLimit="marquee_forever" />
         这样就可以实现了。

         如果是listview的话,只需要在每个item里的textview引用这个自定义view即可实现各自的走马灯效果。


最后

以上就是害怕宝贝最近收集整理的关于Android textview和listview实现水平自动滚动的走马灯效果的全部内容,更多相关Android内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(48)

评论列表共有 0 条评论

立即
投稿
返回
顶部