美文网首页Android开发经验谈程序员
Android | 自动调整文本大小的 TextViews

Android | 自动调整文本大小的 TextViews

作者: 极小光 | 来源:发表于2018-05-30 10:32 被阅读59次

    简评:Auto-Sizing TextViews —— 当 TextView 的布局边界尺寸发生变化时,文本大小可以跟着自动缩放调整。

    有时候我们需要 TextView 根据放入的内容来改变其文本大小,之前 Android 对此并没有太多的支持,在 Android O 之后,新增了这项功能。让我们看看是怎么一回事 ~

    首先,在 build.gradle 文件中添加 v26 支持库或更高的版本。

    implementation 'com.android.support:appcompat-v7:26.1.0'
    implementation 'com.android.support:support-v4:26.1.0'
    

    通过使用支持库,此功能可以兼容 Android 4.0 及更高的版本。然后添加一个 TextView:

    <TextView
        android:id="@+id/textView1"
        android:layout_width="match_parent"
        android:layout_height="100dp"
        android:text="Hello Any Small Text Goes Here"/>
    

    现在在 TextView 中添加 app:autoSizeTextType="uniform":

    <TextView
        android:id="@+id/textView1"
        android:layout_width="match_parent"
        android:layout_height="100dp"
        app:autoSizeTextType="uniform"
        android:text="Hello Any Small Text Goes Here"/>
    
    普通 TextView 和 自动调整大小的 TextView

    你也可以使用这行代码在 Java/Kotlin 执行此操作

    TextViewCompat.setAutoSizeTextTypeWithDefaults(myTextView, 
    TextViewCompat.AUTO_SIZE_TEXT_TYPE_UNIFORM);
    

    如果在 XML 文件中设置了自动调整大小,则不建议将该值"wrap_content"用于layout_widthlayout_height的某个属性TextView

    根据需要,还有两种方法可以调整文本大小:

    1. Granularity(粒度型)
    2. Preset Sizes(预置大小型)

    粒度型

    此模式下,通过设置最小值和最大值来确定一个文本大小变化范围,然后设置一个变化粒度值,TextView 就能够以该粒度值为增减变量,在变化范围内动态缩放文本大小。

    在 XML 中,可以这样完成:

    app:autoSizeMaxTextSize=”100sp” 
        app:autoSizeMinTextSize=”12sp” 
        app:autoSizeStepGranularity=”2sp” 
        app:autoSizeText=”uniform”
    

    在 Java/Kotlin,可以通过调用以下方法来实现:

    TextViewCompat.setAutoSizeTextTypeUniformWithConfiguration(TextView textview, int autoSizeMinTextSize, int autoSizeMaxTextSize, int autoSizeStepGranularity, int unit); 
    
    // Example
    TextViewCompat.setAutoSizeTextTypeUniformWithConfiguration(myTextView, 12, 100, 2, TypedValue.COMPLEX_UNIT_SP);
    
    

    预置大小

    TextView 可以根据预置的值自动调整文本大小。

    在 XML 中,使用 autoSizePresetSizesautoSizePresetSizes布局文件中的属性

    android:autoSizeText=”uniform” 
        android:autoSizePresetSizes=”@array/autosize_text_sizes”
    

    要将数组作为资源访问,在 res/values/arrays.xml 文件中定义数组

    <array name=”autosize_text_sizes”> 
        <item>10sp</item> 
        <item>12sp</item> 
        <item>20sp</item> 
        <item>40sp</item> 
        <item>100sp</item> 
    </array>
    

    在 Java/Kotlin 可以这样实现:

    TextViewCompat.setAutoSizeTextTypeUniformWithPresetSizes(int[] presetSizes, int unit);
    
    // Example
    int[] sizes = getContext().getResources().getIntArray(R.array.autosize_text_sizes)
    TextViewCompat.setAutoSizeTextTypeUniformWithPresetSizes(myTextView, sizes, TypedValue.COMPLEX_UNIT_SP);
    
    

    关于 Auto-Sizing TextViews 就先介绍到这里 ~


    原文链接:Auto-Sizing TextViews in Android
    推荐阅读:怎样减少 Android 应用包 60% 的大小?

    相关文章

      网友评论

        本文标题:Android | 自动调整文本大小的 TextViews

        本文链接:https://www.haomeiwen.com/subject/filtsftx.html