真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

AndroidDrawableTextView圖片文字居中顯示實(shí)例

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

公司主營業(yè)務(wù):網(wǎng)站建設(shè)、成都網(wǎng)站建設(shè)、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出蘭山免費(fèi)做網(wǎng)站回饋大家。

小編的方案是通過自定義TextView實(shí)現(xiàn)。

實(shí)現(xiàn)的效果圖:

Android DrawableTextView圖片文字居中顯示實(shí)例

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

第二行為自定義TextView實(shí)現(xiàn)的效果。

實(shí)現(xiàn)思路:

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

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設(shè)置的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 DrawableTextView圖片文字居中顯示實(shí)例,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!


本文名稱:AndroidDrawableTextView圖片文字居中顯示實(shí)例
分享鏈接:http://weahome.cn/article/jhhcip.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部