日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

android动态设置文本居中显示图片,Android DrawableTextView图片文字居中显示实例

發布時間:2024/7/23 Android 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 android动态设置文本居中显示图片,Android DrawableTextView图片文字居中显示实例 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在我們開發中,TextView設置Android:drawableLeft一定使用的非常多,但Drawable和Text同時居中顯示可能不好控制,有沒有好的辦法解決呢?

小編的方案是通過自定義TextView實現。

實現的效果圖:

注:第一行為原生TextView添加android:drawableLeft

第二行為自定義TextView實現的效果。

實現思路:

繼承TextView,覆蓋onDraw(Canvas canvas),在onDraw中先將canvas進行translate平移,再調用父類onDraw進行繪制。

DrawableTextView.Java:

package com.xing.drawabletextview;

import android.content.Context;

import android.graphics.Canvas;

import android.graphics.drawable.Drawable;

import android.util.AttributeSet;

import android.widget.TextView;

/**

* Created by Administrator on 2017/2/28.

*/

public class DrawableTextView extends TextView {

public DrawableTextView(Context context) {

this(context, null);

}

public DrawableTextView(Context context, AttributeSet attrs) {

this(context, attrs, 0);

}

public DrawableTextView(Context context, AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

}

@Override

protected void onDraw(Canvas canvas) {

// getCompoundDrawables() : Returns drawables for the left, top, right, and bottom borders.

Drawable[] drawables = getCompoundDrawables();

// 得到drawableLeft設置的drawable對象

Drawable leftDrawable = drawables[0];

if (leftDrawable != null) {

// 得到leftDrawable的寬度

int leftDrawableWidth = leftDrawable.getIntrinsicWidth();

// 得到drawable與text之間的間距

int drawablePadding = getCompoundDrawablePadding();

// 得到文本的寬度

int textWidth = (int) getPaint().measureText(getText().toString().trim());

int bodyWidth = leftDrawableWidth + drawablePadding + textWidth;

canvas.save();

canvas.translate((getWidth() - bodyWidth) / 2, 0);

}

super.onDraw(canvas);

}

}

布局文件中引入:

android:layout_width="match_parent"

android:layout_height="100dp"

android:orientation="horizontal">

android:layout_width="0dp"

android:layout_height="wrap_content"

android:layout_weight="1"

android:drawableLeft="@drawable/ic_one"

android:drawablePadding="10dp"

android:gravity="center_vertical"

android:text="21" />

android:layout_width="0dp"

android:layout_height="wrap_content"

android:layout_weight="1"

android:drawableLeft="@drawable/ic_two"

android:drawablePadding="10dp"

android:gravity="center_vertical"

android:text="99" />

android:layout_width="0dp"

android:layout_height="wrap_content"

android:layout_weight="1"

android:drawableLeft="@drawable/ic_three"

android:drawablePadding="10dp"

android:gravity="center_vertical"

android:text="99+" />

以上所述是小編給大家介紹的Android DrawableTextView圖片文字居中顯示實例,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

總結

以上是生活随笔為你收集整理的android动态设置文本居中显示图片,Android DrawableTextView图片文字居中显示实例的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。