Android开发手册TextView属性实现效果盘点
作者:芝麻粒儿 发布时间:2022-03-10 09:29:53
前言
前面小空带大家了解了TextView的属性,实践了一些自定义粗细,阴影效果,链接形文字。
但这还仅仅局限在用她本身的能力来实现的,那么她还能有什么花样呢?
我们先提出三个问题:
例如有些时钟的显示,那如何让文本带有动画效果?
例如如何让一个文本支持多种颜色和大小?
那有没有统一快捷的方案?
我们带着疑问来看解决方案,大佬直接看最后开源项目。
👉实践过程
😜如何实现drawable的动画?
我们用帧动画举例,准备一个序列帧动画,放到drawable-xxhdpi下,在drawable文件夹下创建个动画xml(Android动画是个不小的知识点,后面我们学)配置好,然后在布局中引用。
test_tsxt_anim.xml
<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/anim1" android:duration="80" />
<item android:drawable="@drawable/anim2" android:duration="80" />
<item android:drawable="@drawable/anim3" android:duration="80" />
<item android:drawable="@drawable/anim4" android:duration="80" />
<item android:drawable="@drawable/anim5" android:duration="80" />
<item android:drawable="@drawable/anim6" android:duration="80" />
<item android:drawable="@drawable/anim7" android:duration="80" />
<item android:drawable="@drawable/anim8" android:duration="80" />
<item android:drawable="@drawable/anim9" android:duration="80" />
<item android:drawable="@drawable/anim10" android:duration="80" />
<item android:drawable="@drawable/anim11" android:duration="80" />
<item android:drawable="@drawable/anim12" android:duration="80" />
<item android:drawable="@drawable/anim13" android:duration="80" />
<item android:drawable="@drawable/anim14" android:duration="80" />
</animation-list>
布局引用
<TextView
android:id="@+id/test_text_anim"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:drawableTop="@drawable/test_tsxt_anim"
android:text="接着奏乐,接着舞" />
之后在代码中执行
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_test);
testTextAnim = (TextView) findViewById(R.id.test_text_anim);
Drawable[] drawables = testTextAnim.getCompoundDrawables();
for (Drawable drawable : drawables) {
if (drawable instanceof Animatable) {
((Animatable) drawable).start();
}
}
}
获取view之后利用getCompoundDrawables得到图片,用if判断是否为实现类Animatable的drawable,如下,虽然shape和selector也能用,但是只有animation的if (drawable instanceof Animatable) 才为true。
运行效果:
不过,有的同学会提问:这再怎么看和TextView动画也没关系啊,确实。这只是简单提了提,因为这方面有相关的三方库方便使用,所以详情看前辈的项目即可。感谢开源精神!
😜图文混排
Android官方对TextView的图文混排提供了支持,只需要用HTML语言即可,实现的效果很丰富。
private String testHtml = "<font color=\"#f0717e\">人</font>只要活得够<big>久</big></font>,就总能<big>遇上</big>被自己<font color=\"#f0717e\">蠢</font>到的那一天";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_test);
testTextAnim = (TextView) findViewById(R.id.test_text_anim);
testTextAnim.setText(Html.fromHtml(testHtml, Html.FROM_HTML_MODE_COMPACT));
}
运行效果:
上面是使用的html标签来实现的形式,其实还有一个就是利用SpannableString
testTextSpan1 = (TextView) findViewById(R.id.test_text_span1);
testTextSpan2 = (TextView) findViewById(R.id.test_text_span2);
SpannableString spannableString = new SpannableString("千重要,万重要,一技之长最重要");
spannableString.setSpan(new ForegroundColorSpan(Color.parseColor("#FF0000")), 2, spannableString.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
spannableString.setSpan(new BackgroundColorSpan(Color.parseColor("#00ff00")), 0, 2, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
testTextSpan1.setText(spannableString);
Spannable sp = new SpannableString("啊,这该死的高级感");
sp.setSpan(new AbsoluteSizeSpan(20, true), 0, 2, Spannable.SPAN_INCLUSIVE_INCLUSIVE);
sp.setSpan(new AbsoluteSizeSpan(12, true), 2, 3, Spannable.SPAN_INCLUSIVE_INCLUSIVE);
sp.setSpan(new AbsoluteSizeSpan(30, true), 3, sp.length(), Spannable.SPAN_INCLUSIVE_INCLUSIVE);
sp.setSpan(new ForegroundColorSpan(Color.parseColor("#0000ff")), 2, sp.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
testTextSpan2.setText(sp);
利用SpannableString包裹住字符串,里面有四个参数。
参数1 可以是AbsoluteSizeSpan设置字体大小,也可以是ForegroundColorSpan设置字体颜色,还可以是BackgroundColorSpan设置文字背景颜色。
参数2 想要修改字符串中起始index(start),
参数3 是想要修改字符串中的结束index(end)。
参数4 对参数2和参数3的补充,Spanned.SPAN_EXCLUSIVE_EXCLUSIVE — 不包含两端start和end所在的端点
Spanned.SPAN_EXCLUSIVE_INCLUSIVE — 不包含端start,但包含end所在的端点
Spanned.SPAN_INCLUSIVE_EXCLUSIVE — 包含两端start,但不包含end所在的端点
Spanned.SPAN_INCLUSIVE_INCLUSIVE— 包含两端start和end所在的端点
AbsoluteSizeSpan有两个参数,参数1代表size大小,true代表是android的sp单位,false则是像素单位,建议用true。
😜开源项目
SuperTextView:一个很强大的控件元素,灵动多变,为你提供丰富多彩的功能,炫目效果即刻而至。
来源:https://juejin.cn/post/7027756136145092616


猜你喜欢
- 前言废话不多说直接开始老规矩,文章最后有源码完成效果图棋子加渐变色棋子不加渐变色一、测量1.获取宽高 @Override protected
- MyBatis使用RowBounds实现的分页是逻辑分页,也就是先把数据记录全部查询出来,然在再根据offset和limit截断
- 人机交互过程中,当我们需要机器给我们反馈不确定的数字结果时,就会需要用到随机数了,那么,在Java中,我们应当如何来生成并使用随机数呢?一、
- 在C# 的应用程序开发中, 我们经常要把UI线程和工作线程分开,防止界面停止响应, 同时我们又需要在工作线程中更新UI界面上的控件。但直接访
- 概述中国特色社会主义乱码问题是我们经常会碰到的问题,解决的办法有很多,本文分别介绍了GET方式和POST方式中文乱码解决方案中一劳永逸的办法
- 实例如下所示:System.Net.WebClient myWebClient = new System.Net.WebClient();
- 1.任何一门编程语言均有相关数据类型。C#也不例外,其基本数据类型有int,short,long,float,double,string等。
- 提几个问题,从问题中去了解去学习:他们之间有啥区别?如果我使用notify(),将通知哪个线程?我怎么知道有多少线程在等待,所以我可以使用n
- C#中如何给Excel添加水印我们知道Microsoft Excel并没有内置的功能直接给Excel表添加水印,但是其实我们可以用其他变通的
- 一、首先下载 ZXing.Net地址是:http://zxingnet.codeplex.com/releases/view/117068然
- 一、使用策略枚举来优化if-else看到网上蛮多人推荐使用策略模式来优化if-else,但我总觉得,搞一堆策略类来优化大批量if-else,
- 本文实例讲述了Android4.4电池低电量告警提示原理与实现方法。分享给大家供大家参考,具体如下:之前版本的电池电量低是通过发送 inte
- 兄dei,耐心把我的写的看完,我写的不繁琐,很好理解.IDEA插件之Mybatis Log plugin
- 在进行java编程的时候,我们可以生成可运行的jar文件,但是鉴于平台的不同,我们可能需要将jar文件转化为exe格式。今天,小编就用一款叫
- spring拓展 定义自己的namespace1.查看源码认识spring是怎么加载xml配置的1.1 spring是怎么创建对象的? 查看
- 在Android应用中,图片裁剪也是一个经常用到的功能。Android系统中可以用隐式意图调用系统应用进行裁剪,但是这样做在不同的手机可能表
- easyExcel简介:Java领域解析、生成Excel比较有名的框架有Apache poi、jxl等。但他们都存在一个严重的问题就是非常的
- JAVA 中Spring的@Async用法总结引言: 在Java应用中,绝大多数情况下都是通过同步的方式来实现交互处理的;但是在处理与第三方
- resultMap标签继承、复用、嵌套记录演示 Mybatis 中 resultMap 标签继承、复用(包括跨文件)以及多层嵌套的使用方法,
- Android中Progress的简单实例Android中Progress网上的demo都是瞎扯淡,当然,你们也可以认为我的demo是瞎扯淡