Android中自适应大小的TextView

1.AndroidX包中有一个AppCompatTextView,它是Android标准TextView的增强:

import androidx.appcompat.widget.AppCompatTextView;
public class AppCompatTextView extends TextView implements TintableBackgroundView,
        TintableCompoundDrawablesView, AutoSizeableTextView 

2.AppCompatTextView最明显的特点是可以自适应字体宽度大小变化,

在xml中使用:

<androidx.appcompat.widget.AppCompatTextView
    android:id="@+id/liveMemberCount"
    android:layout_width="27dp"
    android:layout_height="27dp"
    android:layout_below="@+id/image"
    android:layout_marginTop="-3dp"
    android:alpha="0.5"
    android:text="99999"
    android:autoSizeTextType="uniform"
    android:background="@drawable/live_anchor_count_bg"
    android:gravity="center"
    android:textColor="#ffffff"
    android:visibility="visible"
    android:minWidth="27dp"
    app:autoSizeMinTextSize="8dp"
    app:autoSizeMaxTextSize="10dp"
    android:maxLines="1" />

3.本文是在直播界面使用的,统计直播间的观众人数,抖音直播app直播间观众人数的view都是自适应的,没有固定写死,99个人可能TextView的宽带是30dp,1999可能是70dp,我们的需求不管多少人都是27dp。

完整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:id="@+id/liveAnchorStartLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:visibility="visible"
    tools:ignore="ResourceName"
    android:background="@color/colorPrimary">
​
    <RelativeLayout
        android:id="@+id/topLayout"
        android:layout_width="match_parent"
        android:layout_height="60dp"
        android:layout_marginLeft="6dp"
        android:layout_marginTop="25dp"
        android:layout_marginRight="6dp">
​
        <RelativeLayout
            android:layout_width="150dp"
            android:layout_height="30dp"
            android:layout_marginTop="5dp"
            android:alpha="0.5"
            android:background="@drawable/live_anchor_count_bg">
​
            <androidx.cardview.widget.CardView
                android:id="@+id/cardViewImageView"
                android:layout_width="30dp"
                android:layout_height="30dp"
                app:cardCornerRadius="@dimen/public_15dp">
​
                <ImageView
                    android:id="@+id/anchorAvatar"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:src="@mipmap/timg" />
​
            </androidx.cardview.widget.CardView>
​
            <TextView
                android:id="@+id/anchorName"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginLeft="4dp"
                android:layout_marginTop="4dp"
                android:layout_toRightOf="@+id/cardViewImageView"
                android:ellipsize="end"
                android:singleLine="true"
                android:text="主播名称"
                android:textColor="@color/white"
                android:textSize="@dimen/text_size_9" />
​
            <TextView
                android:id="@+id/anchorID"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_alignParentBottom="true"
                android:layout_marginLeft="4dp"
                android:layout_marginBottom="2dp"
                android:layout_toRightOf="@+id/cardViewImageView"
                android:text="直播号/个人ID"
                android:textColor="@color/white"
                android:textSize="@dimen/text_size_9" />
​
            <Button
                android:id="@+id/followButton"
                android:layout_width="40dp"
                android:layout_height="24dp"
                android:layout_alignParentRight="true"
                android:layout_centerVertical="true"
                android:layout_marginRight="5dp"
                android:background="@drawable/live_look_follow_sys_bg"
                android:text="关注"
                android:textColor="@color/white"
                android:textSize="@dimen/text_size_12"
                android:visibility="gone" />
​
        </RelativeLayout>
​
        <TextView
            android:id="@+id/fanTextNumber"
            android:layout_width="wrap_content"
            android:layout_height="18dp"
            android:layout_marginTop="40dp"
            android:alpha="0.5"
            android:background="@drawable/live_anchor_fan_bg"
            android:gravity="center"
            android:minWidth="@dimen/public_75dp"
            android:paddingLeft="5dp"
            android:paddingRight="5dp"
            android:text="粉丝:0"
            android:textColor="@color/white"
            android:textSize="@dimen/text_size_10" />
​
        <TextView
            android:id="@+id/rewardTextNumber"
            android:layout_width="wrap_content"
            android:layout_height="18dp"
            android:layout_marginLeft="5dp"
            android:layout_marginTop="40dp"
            android:layout_toRightOf="@+id/fanTextNumber"
            android:alpha="0.5"
            android:background="@drawable/live_anchor_fan_bg"
            android:gravity="center"
            android:minWidth="@dimen/public_75dp"
            android:paddingLeft="@dimen/dp_10"
            android:paddingRight="10dp"
            android:text="赏金: 0"
            android:textColor="@color/white"
            android:textSize="@dimen/text_size_10" />
​
        <ImageView
            android:id="@+id/netWorkImage"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="5dp"
            android:layout_marginTop="40dp"
            android:layout_toRightOf="@+id/rewardTextNumber"
            android:src="@mipmap/net_work_four"
            android:visibility="gone" />
​
        <TextView
            android:id="@+id/netWorkText"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="5dp"
            android:layout_marginTop="43dp"
            android:layout_toRightOf="@+id/netWorkImage"
            android:text="网络较差"
            android:textColor="#666666"
            android:textSize="10sp"
            android:visibility="gone" />
​
        <RelativeLayout
            android:id="@+id/liveMemberCountLayout"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            android:layout_marginLeft="5dp">
​
            <ImageView
                android:id="@+id/image"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_centerHorizontal="true"
                android:src="@drawable/live_gift_one"
                android:visibility="invisible" />
​
            <androidx.appcompat.widget.AppCompatTextView
                android:id="@+id/liveMemberCount"
                android:layout_width="27dp"
                android:layout_height="27dp"
                android:layout_below="@+id/image"
                android:layout_marginTop="-3dp"
                android:alpha="0.5"
                android:text="99999"
                android:autoSizeTextType="uniform"
                android:background="@drawable/live_anchor_count_bg"
                android:gravity="center"
                android:textColor="#ffffff"
                android:visibility="visible"
                android:minWidth="27dp"
                app:autoSizeMinTextSize="8dp"
                app:autoSizeMaxTextSize="10dp"
                android:maxLines="1" />
        </RelativeLayout>
​
        <androidx.recyclerview.widget.RecyclerView
            android:id="@+id/anchorTopRecyclerView"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="160dp"
            android:layout_toLeftOf="@+id/liveMemberCountLayout"
            android:orientation="horizontal" />
​
    </RelativeLayout>
​
    <LinearLayout
        android:id="@+id/llComment"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_above="@+id/bottomLayout"
        android:layout_below="@+id/topLayout"
        android:orientation="vertical">
​
        <View
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="0.8" />
​
        <FrameLayout
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1">
​
​
            <LinearLayout
                android:id="@+id/ll_gift_container"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:animateLayoutChanges="true"
                android:orientation="vertical" />
        </FrameLayout>
​
        <View
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="0.8" />
​
        <FrameLayout
            android:id="@+id/frameLayoutComment"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1">
​
            <androidx.recyclerview.widget.RecyclerView
                android:id="@+id/commentRecyclerView"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_gravity="bottom"
                android:layout_marginLeft="8dp"
                android:layout_marginRight="8dp" />
        </FrameLayout>
​
    </LinearLayout>
​
​
    <RelativeLayout
        android:id="@+id/bottomLayout"
        android:layout_width="match_parent"
        android:layout_height="@dimen/public_38dp"
        android:layout_alignParentBottom="true"
        android:layout_margin="8dp">
​
        <ImageView
            android:id="@+id/liveComment"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@mipmap/live_comment" />
​
        <ImageView
            android:id="@+id/liveShare"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="@dimen/public_50dp"
            android:src="@mipmap/live_share" />
​
        <ImageView
            android:id="@+id/liveSetQing"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="@dimen/public_100dp"
            android:src="@mipmap/live_watch_qing"
            android:visibility="visible" />
​
        <ImageView
            android:id="@+id/liveShop"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="right"
            android:src="@mipmap/shop_icon"
            android:layout_marginLeft="@dimen/public_150dp"
            android:visibility="visible"/>
​
        <ImageView
            android:id="@+id/liveSetImg"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            android:layout_marginRight="50dp"
            android:src="@mipmap/live_g_icon" />
​
        <ImageView
            android:id="@+id/liveGift"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            android:layout_marginRight="50dp"
            android:src="@mipmap/live_gift"
            android:visibility="gone" />
​
        <ImageView
            android:id="@+id/liveClose"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            android:src="@mipmap/live_close" />
    </RelativeLayout>
</RelativeLayout>

4.Activity中代码:

private void initView() {
    liveMemberCount = findViewById(R.id.liveMemberCount);
    liveClose = findViewById(R.id.liveClose);
    //自适应手机大小
    TextViewCompat.setAutoSizeTextTypeWithDefaults(liveMemberCount, TextViewCompat.AUTO_SIZE_TEXT_TYPE_UNIFORM);
    TextViewCompat.setAutoSizeTextTypeUniformWithConfiguration(liveMemberCount, 8, 10, 1, TypedValue.COMPLEX_UNIT_SP);
    liveMemberCount.setText("8888");
}

5.实现的效果截图如下:

img

img

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!要实现安卓TextView自适应字体大小的效果,可以使用以下方法: 1. 使用AutoSizeTextType属性:在XML布局文件,将TextView的属性设置为`app:autoSizeTextType="uniform"`,这将使TextView的字体大小根据其宽度和高度自动调整。 ```xml <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" app:autoSizeTextType="uniform" /> ``` 2. 使用AutoSizeTextView库:如果您的项目支持Android 8.0(API级别26)以下的版本,可以使用Google提供的AutoSizeTextView库。首先,在项目的build.gradle文件添加以下依赖项: ```groovy dependencies { implementation 'com.android.support:appcompat-v7:28.0.0' implementation 'com.android.support:preference-v7:28.0.0' implementation 'com.android.support:autosize:1.1.2' } ``` 接下来,在XML布局文件使用`AutoSizeTextView`代替`TextView`: ```xml <com.google.android.material.textview.AutoSizeTextView android:layout_width="wrap_content" android:layout_height="wrap_content" /> ``` 这样,AutoSizeTextView会自动根据TextView的宽度和高度调整字体大小。 3. 使用代码适配字体大小:您还可以通过编写代码来适应TextView的字体大小。可以使用Paint类的`setTextSize()`方法来设置字体大小,并根据TextView的宽度和高度进行调整。 ```java TextView textView = findViewById(R.id.textView); textView.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() { @Override public void onGlobalLayout() { textView.getViewTreeObserver().removeOnGlobalLayoutListener(this); int width = textView.getWidth(); int height = textView.getHeight(); float fontSize = calculateFontSize(width, height); // 根据宽度和高度计算字体大小 textView.setTextSize(TypedValue.COMPLEX_UNIT_PX, fontSize); } }); private float calculateFontSize(int width, int height) { // 根据宽度和高度计算字体大小的逻辑 // 可以根据需求自定义计算方法 } ``` 以上是几种实现安卓TextView自适应字体大小的方法,您可以根据项目需求选择适合您的方法进行使用。希望对您有所帮助!如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值