亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

Android編程中TextView寬度過大導致Drawable無法居中問題解決方法

2020-04-11 11:21:16
字體:
來源:轉載
供稿:網友

本文實例講述了Android編程中TextView寬度過大導致Drawable無法居中問題解決方法。分享給大家供大家參考,具體如下:

在做項目的時候,很多時候我們都要用到文字和圖片一起顯示,一般設置TextView的DrawableLeft、DrawableRight、DrawableTop、DrawableBottom就行了。但是有一種情況是當TextView的熟悉是fill_parent或者使用權重的時候并且設置了起Gravity的ceter的時候,Drawable圖片是無法一起居中的,為了解決其,我們一般再套一層布局,然后設置TextView的熟悉是wrap_content,但是有時候嵌套過多的布局的時候,有可能發生StackOverFlow,所以必須要優化,下面說一下其中的一個解決方案。先上圖

這個解決方案很粗糙,局限性很大,文字不能換行,換行之后就不準了,下面是源碼:

package com.example.testandroid; import java.lang.ref.WeakReference; import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Rect; import android.util.AttributeSet; import android.view.MotionEvent; import android.widget.TextView; public class DrawableTextView extends TextView {  private WeakReference<Bitmap> normalReference;  private WeakReference<Bitmap> pressReference;  private WeakReference<Bitmap> showReference;  private int normalColor = Color.WHITE, pressColor = Color.WHITE;  private String text;  private int textWidth = 0;  private int textHeight = 0;  public DrawableTextView(Context context) {   super(context);  }  public DrawableTextView(Context context, AttributeSet attrs) {   super(context, attrs);  }  public DrawableTextView(Context context, AttributeSet attrs, int defStyle) {   super(context, attrs, defStyle);  }  @Override  protected void onFinishInflate() {   super.onFinishInflate();   initText();  }  private void initText() {   text = super.getText().toString();   initVariable();  }  /**   * 初始化,測量Textview內容的長度,高度   */  private void initVariable() {   textWidth = (int) (getPaint().measureText(text));   final Rect rect = new Rect();   getPaint().getTextBounds(text, 0, 1, rect);   textHeight = rect.height();  }  /**   * 設置TextView的內容   * @param text   */  public void setText(String text) {   this.text = text;   initVariable();   invalidate();  }  /**   * 獲取TextView內容   */  public String getText() {   return text;  }  /**   * 設置TextView的Drawable內容,目前僅支持DrawableLeft   * @param normalDrawableId   *    DrawableLeft的normal狀態Id   * @param pressDrawableId   *    DrawableLeft的press狀態的Id(沒有press狀態,請傳-1)   */  public void setDrawableLeftId(final int normalDrawableId, final int pressDrawableId) {   normalReference = new WeakReference<Bitmap>(BitmapFactory.decodeResource(getResources(), normalDrawableId));   if (pressDrawableId != -1) {    pressReference = new WeakReference<Bitmap>(BitmapFactory.decodeResource(getResources(), pressDrawableId));   }   showReference = normalReference;   invalidate();  }  /**   * 設置TextView的Color   * @param normalColor   *    TextView normal狀態的Color值   * @param pressDrawableId   *    TextView press狀態的Color值(如果沒有press狀態,請傳與normal狀態的值)   */  public void setTextColor(final int normalColor, final int pressColor) {   this.normalColor = normalColor;   this.pressColor = pressColor;   getPaint().setColor(normalColor);   initVariable();  }  @Override  protected void onDraw(Canvas canvas) {   if (showReference != null && showReference.get() != null) {    final int bitmapWidth = showReference.get().getWidth();    final int bitmapHeight = showReference.get().getHeight();    final int viewHeight = getHeight();    final int drawablePadding = getCompoundDrawablePadding();    final int start = (getWidth() - (bitmapWidth + drawablePadding + textWidth)) >> 1;    canvas.drawBitmap(showReference.get(), start, (viewHeight >> 1) - (bitmapHeight >> 1), getPaint());    /**     * 注意改方法,第三個參數y,本人也被誤導了好久,原來在畫文字的時候,y表示文字最后的位置(不是下筆點的起始位置)     * 所以為什么 是TextView高度的一半(中間位置) + 文字高度的一半 = 文字居中     */    canvas.drawText(text, start + drawablePadding + bitmapWidth, (viewHeight >> 1) + (textHeight >> 1), getPaint());   }  }  @Override  public boolean onTouchEvent(MotionEvent event) {   if (event.getAction() == MotionEvent.ACTION_DOWN) {    if (pressReference != null && pressReference.get() != null) {     showReference = pressReference;    }    getPaint().setColor(pressColor);   } else if (event.getAction() == MotionEvent.ACTION_UP) {    if (normalReference != null && normalReference.get() != null) {     showReference = normalReference;    }    getPaint().setColor(normalColor);   }   invalidate();   return super.onTouchEvent(event);  } }

xml布局:

<com.example.testandroid.DrawableTextView android:id="@+id/my_textview" android:layout_width="fill_parent" android:layout_marginTop="20dp" android:background="@drawable/text_selector" android:drawablePadding="8dp" android:textColor="@color/standard_orange" android:layout_height="wrap_content" android:padding="15dp" android:textSize="16sp" android:text="有Drawable的TextView" />

調用代碼:

DrawableTextView drawableTextView = (DrawableTextView) getView().findViewById(R.id.my_textview);drawableTextView.setDrawableLeftId(R.drawable.bg_btn_delete_normal, R.drawable.bg_btn_delete_pressed);drawableTextView.setTextColor(getResources().getColor(R.color.standard_orange), getResources().getColor(R.color.standard_white));drawableTextView.setText("我在動態修改Text啦");

其實還有更加方便的方法,下面朋友借鑒某個網友的代碼(地址我就不知道了):

@Override protected void onDraw(Canvas canvas) {  Drawable[] drawables = getCompoundDrawables();  if (drawables != null) {   Drawable drawableLeft = drawables[0];   if (drawableLeft != null) {    final float textWidth = getPaint().measureText(getText().toString());    final int drawablePadding = getCompoundDrawablePadding();    final int drawableWidth = drawableLeft.getIntrinsicWidth();    final float bodyWidth = textWidth + drawableWidth + drawablePadding;    canvas.translate((getWidth() - bodyWidth) / 2, 0);   }  }  super.onDraw(canvas); }

xml布局:

<com.example.testandroid.DrawableTextView android:id="@+id/my_textview" android:layout_width="fill_parent" android:layout_marginTop="20dp" android:background="@drawable/text_selector" android:drawablePadding="8dp" android:drawableLeft="@drawable/clear_edittext_selector" android:textColor="@color/text_color_selector" android:layout_height="wrap_content" android:padding="15dp" android:textSize="16sp" android:text="有Drawable的TextView" />

嗯,自己寫這個東西,也學到了一些東西,大家有什么更好的方法,大家可以討論一下。

希望本文所述對大家Android程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕国产精品久久| 久久精品国产96久久久香蕉| 欧美色视频日本版| 国产亚洲一区二区在线| 欧美性猛交xxxx黑人猛交| 久久成人精品视频| 在线观看中文字幕亚洲| 亚洲欧美成人一区二区在线电影| 成人免费观看49www在线观看| 国产精品亚洲激情| 欧美中文在线视频| 97视频在线免费观看| 国产97在线|亚洲| 欧美限制级电影在线观看| 久久免费精品日本久久中文字幕| 97人人模人人爽人人喊中文字| 亚洲精品v天堂中文字幕| 成人午夜两性视频| 亚洲性日韩精品一区二区| 在线观看日韩视频| 国精产品一区一区三区有限在线| 色www亚洲国产张柏芝| 成人网中文字幕| 久久久国产一区二区| 成人在线免费观看视视频| www.久久久久久.com| 丝袜情趣国产精品| 国产精品午夜一区二区欲梦| 亚洲电影成人av99爱色| 亚洲美女性视频| 国产亚洲激情在线| 精品亚洲永久免费精品| 欧美激情在线有限公司| 国产精品羞羞答答| 日韩欧美国产激情| 国产精品久久视频| 亚洲日韩第一页| 国产精品电影在线观看| 国产视频久久久| 亚洲精品永久免费| 日本中文字幕久久看| 亚洲精品美女久久| 欧美精品久久久久久久| 国产精品老女人精品视频| 国产亚洲视频在线观看| 欧美一级在线播放| 久久视频在线看| 91高清免费在线观看| 亚洲视频网站在线观看| 日韩免费看的电影电视剧大全| 亚洲激情中文字幕| 久久人人爽人人爽人人片亚洲| 精品精品国产国产自在线| 久久夜色撩人精品| 91免费电影网站| 日韩美女免费观看| 久久在线视频在线| 欧美大胆在线视频| 中文字幕久久亚洲| 精品福利在线视频| 欧美日韩中文字幕在线| 日韩在线观看免费全集电视剧网站| 欧美日韩精品在线播放| 国产精品偷伦免费视频观看的| 精品国产福利视频| 久久99久久99精品中文字幕| 国产成人精品在线播放| 国产91精品久久久久| 日韩在线观看成人| 欧美成人精品一区二区三区| 中文字幕国产精品久久| 国产午夜精品麻豆| 国产精品久久久精品| 久久久久久久影视| 亚洲图片制服诱惑| 日韩av在线免费看| 九九热视频这里只有精品| 一区二区三区国产在线观看| 欧美激情小视频| 亚洲一区免费网站| 国产精品网红直播| 午夜精品国产精品大乳美女| 国产激情999| 久久精品国产亚洲7777| 91久久久久久久一区二区| 国内精品小视频在线观看| 亚洲综合一区二区不卡| 国产精品小说在线| 国内精品400部情侣激情| 青青青国产精品一区二区| 成人精品网站在线观看| 色婷婷综合成人av| 国产精品第2页| 久久久国产影院| 亚洲精品自拍偷拍| 国产精品久久久久不卡| 久久99国产精品久久久久久久久| 7777免费精品视频| 伊人av综合网| 美女av一区二区三区| 欧美精品久久久久| 热久久免费视频精品| 97色在线视频观看| 91丝袜美腿美女视频网站| 91香蕉嫩草影院入口| 最近中文字幕2019免费| 国产91精品不卡视频| 蜜月aⅴ免费一区二区三区| 亚洲色图15p| 精品福利樱桃av导航| 伦伦影院午夜日韩欧美限制| 久久久av网站| 亚洲美女又黄又爽在线观看| 欧美一区二区三区四区在线| 国产精品美女久久| 国产福利精品在线| 欧美精品一本久久男人的天堂| 日韩一区二区三区xxxx| 国产综合视频在线观看| 亚洲男人天堂手机在线| 一区二区三区四区视频| 亚洲精品视频在线观看视频| 秋霞成人午夜鲁丝一区二区三区| 亚洲精品一区二区在线| 亚洲2020天天堂在线观看| 国产精品9999| 亚洲一区二区三区777| 夜夜嗨av一区二区三区四区| 国产午夜精品全部视频在线播放| 国产精品美乳一区二区免费| 欧美成在线视频| 久久精品亚洲一区| 国产亚洲一级高清| 91欧美精品午夜性色福利在线| 丝袜情趣国产精品| 亚洲欧洲午夜一线一品| 欧美高清在线观看| 欧美交受高潮1| 国产a∨精品一区二区三区不卡| 日韩欧美在线视频观看| 国产丝袜一区二区三区免费视频| 久久精品中文字幕一区| 欧美不卡视频一区发布| 亚洲美女av网站| 久久久免费观看视频| 国产精品麻豆va在线播放| 亚洲第一区在线| 国产女人精品视频| 国产日韩精品视频| 欧美电影《睫毛膏》| 黑人欧美xxxx| 少妇激情综合网| 国产精品精品一区二区三区午夜版| 97碰在线观看| 中文字幕欧美日韩va免费视频| 国产91精品青草社区| 亚洲乱码一区av黑人高潮| 中文国产亚洲喷潮| 亚洲欧美日韩在线一区| 国产成人精品久久二区二区91| 久久中文精品视频| 亚洲最大av在线| 国产精品吊钟奶在线| 自拍偷拍免费精品|