Android(安卓)TextView设置多样式文本,跑马灯以及霓虹灯效果
16lz
2021-01-26
1.设置TextView字体颜色
1)使用Html标签方式设置
代码如下:
tvTest1.setText(Html.fromHtml("电影《斗牛》,黄渤和奶牛的爱情故事。"));
效果图如下:
使用Html标签设置TextView文本样式2)使用SpannableString设置文本样式
新建一个SpannableString对象,构造函数传入string字符串。
接下来设置span,span的类型有ForegroundColorSpan,BackgroundColorSpan,RelativeSizeSpan,StrikethroughSpan,UnderlineSpan,SuperscriptSpan,SubscriptSpan,StyleSpan,ImageSpan,ClickableSpan,URLSpan。
- ForegroundColorSpan():字体颜色。
- BackgroundColorSpan():字体背景颜色。
- RelativeSizeSpan():相对字体大小。
- StrikethroughSpan():删除线。
- UnderlineSpan():下划线。
- SuperscriptSpan():上标。
- SubscriptSpan():下标。
- StyleSpan():字体风格:加粗,斜体。
- ImageSpan():添加图片。
- ClickableSpan():字体可点击。
- URLSpan():URL。
创建好Span后,调用SpannableString对象的setSpan()方法设置Span。setSpan(Object what, int start, int end, int flags)四个参数含义分别是Span类型,设置该Span的起始下标,设置该Span的结束下标,设置该Span的下标计算方式。Span下标计算方式如下:
- Spanned.SPAN_INCLUSIVE_EXCLUSIVE:起始下标到终止下标,包括起始下标,不包括终止下标。
- Spanned.SPAN_INCLUSIVE_INCLUSIVE:起始下标到终止下标,包括起始下标和终止下标。
- Spanned.SPAN_EXCLUSIVE_INCLUSIVE:起始下标到终止下标,不包括起始下标,包括终止下标。
- Spanned.SPAN_EXCLUSIVE_EXCLUSIVE:起始下标到终止下标,不包括起始下标和终止下标。
代码如下:
String str = "电影《斗牛》,黄渤和奶牛的爱情故事。"; //字体颜色 SpannableString spForegroundColor = new SpannableString(str); ForegroundColorSpan foregroundColorSpan = new ForegroundColorSpan(Color.RED); spForegroundColor.setSpan(foregroundColorSpan, 2, 6, Spanned.SPAN_INCLUSIVE_INCLUSIVE); tvSpannableStringForegroundColor.setText(spForegroundColor); //背景颜色 SpannableString spBackgroundColor = new SpannableString(str); BackgroundColorSpan backgroundColorSpan = new BackgroundColorSpan(Color.RED); spBackgroundColor.setSpan(backgroundColorSpan, 2, 6, Spanned.SPAN_INCLUSIVE_INCLUSIVE); tvSpannableStringBackgroundColor.setText(spBackgroundColor); //相对字体大小 SpannableString spRelativeSize = new SpannableString(str); RelativeSizeSpan relativeSizeSpan = new RelativeSizeSpan(1.5f); spRelativeSize.setSpan(relativeSizeSpan, 2, 6, Spanned.SPAN_INCLUSIVE_INCLUSIVE); tvSpannableStringRelativeSize.setText(spRelativeSize); //删除线 SpannableString spStrikethrough = new SpannableString(str); StrikethroughSpan strikethroughSpan = new StrikethroughSpan(); spStrikethrough.setSpan(strikethroughSpan, 2, 6, Spanned.SPAN_INCLUSIVE_INCLUSIVE); tvSpannableStringStrikethrough.setText(spStrikethrough); //下划线 SpannableString spUnderline = new SpannableString(str); UnderlineSpan underlineSpan = new UnderlineSpan(); spUnderline.setSpan(underlineSpan, 2, 6, Spanned.SPAN_INCLUSIVE_INCLUSIVE); tvSpannableStringUnderline.setText(spUnderline); //上标 SpannableString spSuperscript = new SpannableString(str); SuperscriptSpan superscriptSpan = new SuperscriptSpan(); spSuperscript.setSpan(superscriptSpan, 2, 6, Spanned.SPAN_INCLUSIVE_INCLUSIVE); tvSpannableStringSuperscript.setText(spSuperscript); //下标 SpannableString spSubscript = new SpannableString(str); SubscriptSpan subscriptSpan = new SubscriptSpan(); spSubscript.setSpan(subscriptSpan, 2, 6, Spanned.SPAN_INCLUSIVE_INCLUSIVE); tvSpannableStringSubscript.setText(spSubscript); //字体风格:加粗 SpannableString spStyle = new SpannableString(str); StyleSpan styleSpan = new StyleSpan(Typeface.BOLD); spStyle.setSpan(styleSpan, 2, 6, Spanned.SPAN_INCLUSIVE_INCLUSIVE); tvSpannableStringStyle.setText(spStyle); //图片 SpannableString spImage = new SpannableString("电影《斗牛》表情,黄渤和奶牛的爱情故事。"); Drawable drawable = getResources().getDrawable(R.mipmap.kb); drawable.setBounds(0, 0, 42, 42); ImageSpan imageSpan = new ImageSpan(drawable); spImage.setSpan(imageSpan, 6, 8, Spanned.SPAN_INCLUSIVE_INCLUSIVE); tvSpannableStringImage.setText(spImage); //可点击 SpannableString spClickable = new SpannableString(str); ClickableSpan clickableSpan = new ClickableSpan() { @Override public void onClick(View widget) { ToastUtil.showToast("这是一个ClickableSpan"); } }; spClickable.setSpan(clickableSpan, 2, 6, Spanned.SPAN_INCLUSIVE_INCLUSIVE); //调用TextView的setMovementMethod()方法让超链接起作用。 //或者给该TextView添加属性android:autoLink,设置当文本为URL链接/email/电话/号码/map时, // 文本是否显示为可点击的连接,值有:none/web/email/phone/map/all tvSpannableStringClickable.setMovementMethod(LinkMovementMethod.getInstance()); tvSpannableStringClickable.setText(spClickable); //URL SpannableString spUrl = new SpannableString(str); URLSpan urlSpan = new URLSpan("https://blog.csdn.net/zhaohuiyang_949"); spUrl.setSpan(urlSpan, 2, 6, Spanned.SPAN_INCLUSIVE_INCLUSIVE); //调用TextView的setMovementMethod()方法让超链接起作用。 tvSpannableStringUrl.setMovementMethod(LinkMovementMethod.getInstance()); tvSpannableStringUrl.setText(spUrl);
效果图如下:
SpannableString设置各种字体样式2.跑马灯效果
文本设置跑马灯效果,只需要在xml
- android:ellipsize 当文本过长时,文本显示方式,start在文本开头显示省略号,end在文本末尾显示省略号,middle在文本中间显示省略号,marquee以跑马灯形式显示(横向滚动)。
- android:marqueeRepeatLimit 在设置了android:ellipsize="marquee"属性后,设置滚动重复次数,marquee_forever表示无限次。
- android:focuseableTouchMode 是否在触摸模式下获取焦点。
- android:focuseable 控件是否能获取焦点。
- android:singleLine 是否以单行显示文本。
- 注:focuseableTouchMode和focusable属性是必须要的,无法获取焦点的情况下跑马灯效果无效。
代码如下:
效果如图:
跑马灯3.霓虹灯效果
实现思路:利用线程Handler和定时器Timer,Timer每隔一段时间发送消息,Handler接收消息后,改变TextView的背景颜色.。直接放代码,关键点代码中都有注释。
代码如下:
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
MainActivity.java
package f3.nsu.com.neon; import android.graphics.Color;import android.os.Handler;import android.os.Message;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.widget.TextView; import java.util.Timer;import java.util.TimerTask; /** * TextView霓虹灯 */public class MainActivity extends AppCompatActivity { //存TextView的ID private int[] textIds = new int[]{R.id.text01,R.id.text02,R.id.text03,R.id.text04,R.id.text05}; //存颜色 private int[] colors = new int[]{Color.BLACK,Color.BLUE,Color.CYAN,Color.DKGRAY,Color.GRAY}; //绑定控件的用的TextView数组 private TextView[] views = new TextView[textIds.length]; private Handler mHandler; private int currentColor = 0; //从哪个颜色开始 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //循环遍历ID数组绑定控件 for (int i = 0;i
效果如图:
TextView霓虹灯效果
更多相关文章
- 使用ViewPager实现android软件使用向导的功能
- Android(安卓)TextView等控件不为人知的秘密
- Android(安卓)TextView学习
- Android(安卓)Transition——提高一点点篇
- Android的Toolbar(含溢出菜单设置[弹出菜单的使用])的使用PopMen
- SystemProperties與Settings.System
- Notification的功能与用法
- Android之TextView动态设置图片
- Android切换语言不重启应用的解决方案