zoukankan      html  css  js  c++  java
  • Android 自己定义TextView 实现文本间距

    这里写图片描写叙述

    转载请标明出处: http://blog.csdn.net/u011974987/article/details/50845269

    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();
        }
    
        @Override
        public void setText(CharSequence text, BufferType type) {
            originalText = text;
            applyLetterSpacing();
        }
    
        @Override
        public 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 文件例如以下:
    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:paddingBottom="@dimen/activity_vertical_margin"
        android:paddingLeft="@dimen/activity_horizontal_margin"
        android:paddingRight="@dimen/activity_horizontal_margin"
        android:paddingTop="@dimen/activity_vertical_margin"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"
        tools:context="com.woyou.spacingtextview.MainActivity"
        tools:showIn="@layout/activity_main">
    
        <com.woyou.spacingtextview.SpacingTextView
            android:id="@+id/space_text"
            android:layout_width="wrap_content"
            android:lineSpacingExtra="13dp"
            android:layout_height="wrap_content"
            android:text="@string/test" />
    </RelativeLayout>

    以上代码使用起来非常方便。加入到自己的项目中看下效果。

    TextView控件以开源:SpacingTextView
    假设你想实现TextView的 文本对齐;请參考开源项目:AlignTextView

  • 相关阅读:
    大整数相加算法
    java中String和char的区别
    Git命令
    Dart随记
    用nodejs或者Chrome控制台的js对URI进行编码或解码
    Rust执行cmd或shell命令
    cargo expand用于查看被宏隐藏的代码
    Blocking waiting for file lock on package cache
    Rust生命周期之个人理解
    Rust为基础类型实现Trait
  • 原文地址:https://www.cnblogs.com/cynchanpin/p/7112698.html
Copyright © 2011-2022 走看看