文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Android编程中TextView宽度过大导致Drawable无法居中问题解决方法

2022-06-06 09:38

关注

本文实例讲述了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(); 
 } 
  
 private void initVariable() { 
  textWidth = (int) (getPaint().measureText(text)); 
  final Rect rect = new Rect(); 
  getPaint().getTextBounds(text, 0, 1, rect); 
  textHeight = rect.height(); 
 } 
  
 public void setText(String text) { 
  this.text = text; 
  initVariable(); 
  invalidate(); 
 } 
  
 public String getText() { 
  return text; 
 } 
  
 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(); 
 } 
  
 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()); 
    
   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程序设计有所帮助。

您可能感兴趣的文章:Android开发使用Drawable绘制圆角与圆形图案功能示例Android自定义Drawable实现圆形和圆角Android自定义Drawable实现圆角效果Android Bitmap和Drawable相互转换的简单代码android 放大镜ShapeDrawable妙用分享android中图形图像处理之drawable用法分析基于android中的各种颜色在drawable.xml中的值详解Android App开发中将View或Drawable转为Bitmap的方法Android LayerDrawable使用实例Android 让自定义TextView的drawableLeft与文本一起居中关于Android中drawable必知的一些规则Android开发基于Drawable实现圆角矩形的方法


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-移动开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯