Android系统中TextView默认显示中文时会比较紧凑,不是很美观。为了让每行保持一定的行间距,可以设置属性android:lineSpacingExtra或android:lineSpacingMultiplier。 
但是有时候我们需要在TextView的文本之间有间距,两个字的话,我们可以在xml文件中,用敲空格的方式来实现,如果有很多文本或者是一个变量的文本呢。我们还这样用敲空格的方式来实现吗?oh no~! 
如何实现行间距和文本间距呢?(请往下看 ↓)。

1、设置TextView的行间距

在TextView控件中添加属性:

android:lineSpacingExtra="13dp" //设置行间距

android:lineSpacingMultiplier="1.2" //设置行间距的倍数。如”1.2”

2、设置TextView的文本间距

  • 先看下效果图: 
  • 自定义的TextView 的代码如下:
    package com.woyou.spacingtextview;

    import android.content.Context;
    import android.text.Spannable;
    import android.text.SpannableString;
    import android.text.style.ScaleXSpan;
    import android.util.AttributeSet;
    import android.widget.TextView;

    /**
    * Created by Xiho on 2016/3/7.
    */public class SpacingTextView extends TextView{private float letterSpacing = LetterSpacing.BIGGEST;
    private CharSequence originalText = "";

    public SpacingTextView(Context context) {
    super(context);
    }

    public SpacingTextView(Context context, AttributeSet attrs){
    super(context, attrs);
    originalText = super.getText();
    applyLetterSpacing();
    this.invalidate();
    }

    public SpacingTextView(Context context, AttributeSet attrs, int defStyle){
    super(context, attrs, defStyle);
    }

    public float getLetterSpacing() {
    return letterSpacing;
    }

    public void setLetterSpacing(float letterSpacing) {
    this.letterSpacing = letterSpacing;
    applyLetterSpacing();
    }

    @Overridepublic void setText(CharSequence text, BufferType type) {
    originalText = text;
    applyLetterSpacing();
    }

    @Overridepublic CharSequence getText() {
    return originalText;
    }

    /**
    * 字距为任何字符串(技术上,一个简单的方法为CharSequence不使用)的TextView
    */private void applyLetterSpacing() {
    if (this == null || this.originalText == null) return;
    StringBuilder builder = new StringBuilder();
    for(int i = 0; i < originalText.length(); i++) {
    String c = ""+ originalText.charAt(i);
    builder.append(c.toLowerCase());
    if(i+1 < originalText.length()) {
    builder.append("\u00A0");
    }
    }
    SpannableString finalText = new SpannableString(builder.toString());
    if(builder.toString().length() > 1) {
    for(int i = 1; i < builder.toString().length(); i+=2) {
    finalText.setSpan(new ScaleXSpan((letterSpacing+1)/10), i, i+1, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
    }
    }
    super.setText(finalText, BufferType.SPANNABLE);
    }

    public class LetterSpacing {public final static float NORMAL = 0;
    public final static float NORMALBIG = (float)0.025;
    public final static float BIG = (float)0.05;
    public final static float BIGGEST = (float)0.2;
    }
    }

  • 在activity 中使用:
    private SpacingTextView mSpacingTextView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mSpacingTextView = (SpacingTextView) findViewById(R.id.space_text);
    mSpacingTextView.setText(getResources().getString(R.string.test));
    //Or any float. To reset to normal, use 0 or LetterSpacingTextView.Spacing.NORMAL
    mSpacingTextView.setLetterSpacing(10);

    }

  • xml 文件如下:

    1. <?xml version="1.0" encoding="utf-8"?>
    2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. xmlns:app="http://schemas.android.com/apk/res-auto"
    4. xmlns:tools="http://schemas.android.com/tools"
    5. android:layout_width="match_parent"
    6. android:layout_height="match_parent"
    7. android:paddingBottom="@dimen/activity_vertical_margin"
    8. android:paddingLeft="@dimen/activity_horizontal_margin"
    9. android:paddingRight="@dimen/activity_horizontal_margin"
    10. android:paddingTop="@dimen/activity_vertical_margin"
    11. app:layout_behavior="@string/appbar_scrolling_view_behavior"
    12. tools:context="com.woyou.spacingtextview.MainActivity"
    13. tools:showIn="@layout/activity_main">
    14. <com.woyou.spacingtextview.SpacingTextView
    15. android:id="@+id/space_text"
    16. android:layout_width="wrap_content"
    17. android:lineSpacingExtra="13dp"
    18. android:layout_height="wrap_content"
    19. android:text="@string/test" />
    20. </RelativeLayout>

    以上代码使用起来很方便,添加到自己的项目中看下效果。

TextView控件以开源:SpacingTextView 
如果你想实现TextView的 文本对齐;请参考开源项目:AlignTextView

Android 自定义TextView 实现文本间距的更多相关文章

  1. Android 自己定义TextView 实现文本间距

    转载请标明出处: http://blog.csdn.net/u011974987/article/details/50845269: Android系统中TextView默认显示中文时会比較紧凑.不是 ...

  2. [置顶] android 自定义TextView

    系统自带的控件TextView有时候没满一行就换行了,为了解决这个问题,自定义了一个TextView,只有一行显示不完全的情况下才会去换行显示,代码如下: package com.open.textv ...

  3. Android 自定义表格显示数据

    Android 自定义TextView控件,用来组成表格方便数据的展示. 首先看一下效果 样式不是很好看,需要用的可以自己优化一下. 实现方式很简单. 1.自定义控件 MyTableTextView ...

  4. Android自定义ScrollView分段加载大文本数据到TextView

    以下内容为原创,转载时请注明链接地址:http://www.cnblogs.com/tiantianbyconan/p/3311658.html 这是我现在碰到的一个问题,如果需要在TextView中 ...

  5. [Android教程]TextView使用SpannableString设置复合文本

    TextView通常用来显示普通文本,但是有时候需要对其中某些文本进行样式.事件方面的设置.Android系统通过SpannableString类来对指定文本进行相关处理,具体有以下功能: 1.Bac ...

  6. [原创]Android秒杀倒计时自定义TextView

    自定义TextView控件TimeTextView代码: import android.content.Context; import android.content.res.TypedArray; ...

  7. 我的Android进阶之旅------> Android为TextView组件中显示的文本添加背景色

    通过上一篇文章 我的Android进阶之旅------> Android在TextView中显示图片方法 (地址:http://blog.csdn.net/ouyang_peng/article ...

  8. Xamarin Android自定义文本框

    xamarin android 自定义文本框简单的用法 关键点在于,监听EditText的内容变化,不同于java中文本内容变化去调用EditText.addTextChangedListener(m ...

  9. Android开发学习笔记-自定义TextView属性模版

    如果项目中有很多个控件使用的是同一种样式,则为了方便,可以将样式设置到系统中去,这样使用的时候会方便很多. 下面是自定义样式模版的方法. 1.在style.xml文件中添加自己要设置的样式内容 < ...

随机推荐

  1. spoj227 树状数组插队序列问题

    插队问题和线段树解决的方式一样,每个结点维护值的信息是该节点之前的空位有多少,然后从后往前插点即可 注意该题要求输出的是从左往右输出每个士兵的等级,即问士兵最后排在第几个位置 /* 树状数组维护前i个 ...

  2. MVC开发中的常见错误-06-"无法在发送 HTTP 标头之后进行重定向。"

    通过监视可以看到: 原来是跳转到登录页面后,登录页面中又发送了一个GeMneuItems的请求,用于加载页面图片

  3. JQuery+Ajax实战三级下拉列表联动(八)

    本片文章为练习,项目中不会这样写: 一:涉及到的知识点: jQuery Dom操作 jQuery Ajax操作 ASP.net中的json操作 二:用了自动代码生成器 1.Dal层的代码: publi ...

  4. Spring MVC的前端控制器模式

    前端控制器模式 spring mvc也是依赖servlet,所以spring mvc的请求处理是从一个servlet开始,这个servlet就是DispatcherServlet.前端控制器模式(Fr ...

  5. hdu 1542

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=1542 题意: 求所给矩形的覆盖面积 题解: 利用扫描线的思想,先将坐标离散化,之后以y轴分成多个矩形求解, ...

  6. k8s 使用

    转自:https://blog.csdn.net/zyc88888/article/details/79281954

  7. POJ1151Atlantis 矩形面积并 扫描线 线段树

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - POJ1151 题意概括 给出n个矩形,求他们的面积并. n<=100 题解 数据范围极小. 我们分3种 ...

  8. Matrix PKU 2155

    问题描述 给定N * N矩阵A,其元素为0或1.A [i,j]表示第i行和第j列中的数字.最初我们有A [i,j] = 0(1 <= i,j <= N). 我们可以通过以下方式更改矩阵.给 ...

  9. 025 如何利用github绑定自己的域名

    这个以前是看同时的文档的,最近重新配置了一次,还是感觉同时的这个文档挺好的,就不再重新书写了,只复制一个连接. https://blog.csdn.net/iliujie/article/detail ...

  10. 洛谷 [P1024]一元三次方程求解【二分答案】

    题目链接:https://www.luogu.org/problemnew/show/P1024 题目描述 有形如:ax3+bx2+cx+d=0 这样的一个一元三次方程.给出该方程中各项的系数(a,b ...