美文网首页Android开发常用代码Android知识Android学习
Android 优化布局(解决TextView drawable

Android 优化布局(解决TextView drawable

作者: 赫丹 | 来源:发表于2016-11-08 15:30 被阅读6191次

    今天分享一个Layout布局中的一个小技巧,希望看过之后你也可以写出性能更好的布局,我个人的目的是用最少的view写出一样的效果布局

    用TextView同时显示图片和文字:

    先看一下效果图

    图像 3.png
    以上这四块区域相信大家在项目中经常遇到吧!(一般的写法ImageView与TextView的组合)现在用一个自定义的TextView就完成能达到一样的效果,并且也可以设置背景选择器、图片的尺寸大小,不需要嵌套多层布局在设置相关的属性

    第一块Xml中的代码

        <com.~~~~~~.TextDrawable
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@drawable/textdrawable"
            android:clickable="true"
            android:drawablePadding="10dp"
            android:gravity="center_vertical"
            android:padding="@dimen/space_20"
            android:text="设置"
            android:textColor="@color/black_252c3d"
            android:textSize="@dimen/textsize_20sp_in_normal"
            app:leftDrawable="@drawable/tab_more_unselect"
            app:leftDrawableHeight="@dimen/space_60"
            app:leftDrawableWidth="@dimen/space_60"
            app:rightDrawable="@drawable/iconfont_youjiantou"
            app:rightDrawableHeight="20dp"
            app:rightDrawableWidth="10dp"
            />
        <Space
            android:layout_width="match_parent"
            android:layout_height="0.5dp"
            android:background="@color/gray_888888"
            />
    

    下面的分割线我建议用Space这个控件,它是一个非常轻量级的控件

    第二块Xml中的代码

    <com.~~~~~~.TextDrawable
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@drawable/textdrawable"
            android:clickable="true"
            android:drawablePadding="10dp"
            android:gravity="center_vertical"
            android:padding="@dimen/space_20"
            android:text="消息"
            android:textColor="@color/black_252c3d"
            android:textSize="@dimen/textsize_20sp_in_normal"
            app:leftDrawable="@drawable/tab_speech_unselect"
            app:leftDrawableHeight="@dimen/space_60"
            app:leftDrawableWidth="@dimen/space_60"
            />
    

    第三块Xml中的代码

     <com.~~~~~~.TextDrawable
                android:layout_width="0dp"
                android:layout_weight="1"
                android:layout_height="wrap_content"
                android:background="@drawable/textdrawable"
                android:clickable="true"
                android:drawablePadding="10dp"
                android:gravity="center"
                android:padding="@dimen/space_20"
                android:text="首页"
                android:textColor="@color/colorPrimary"
                android:textSize="@dimen/textsize_20sp_in_normal"
                app:topDrawable="@drawable/tab_home_select"
                app:topDrawableHeight="@dimen/space_60"
                app:topDrawableWidth="@dimen/space_60"
                />
    

    第四块Xml中的代码(图片按钮)

     <com.hightsstudent.highsstudent.ui.widget.TextDrawable
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:background="@drawable/textdrawable"
            android:clickable="true"
            android:drawablePadding="10dp"
            android:gravity="center_vertical"
            android:padding="@dimen/space_15"
            android:text="退出"
            android:textColor="@color/black_252c3d"
            android:textSize="@dimen/textsize_20sp_in_normal"
            app:rightDrawable="@drawable/icon_backs"
            app:rightDrawableHeight="@dimen/space_80"
            app:rightDrawableWidth="@dimen/space_80"
            />
    

    下面贴出TextDrawable.java代码

    /**
     * Created by Dengxiao on 2016/11/8.
     */
    
    public class TextDrawable extends TextView {
        private Drawable drawableLeft;
        private Drawable drawableRight;
        private Drawable drawableTop;
        private int leftWidth;
        private int rightWidth;
        private int topWidth;
        private int leftHeight;
        private int rightHeight;
        private int topHeight;
        private Context mContext;
    
        public TextDrawable(Context context) {
            this.mContext=context;
            this(context, null, 0);
        }
    
        public TextDrawable(Context context, AttributeSet attrs) {
            this.mContext=context;
            this(context, attrs, 0);
        }
    
        public TextDrawable(Context context, AttributeSet attrs, int defStyleAttr) {
            super(context, attrs, defStyleAttr);
            this.mContext=context;
            init(context, attrs);
        }
    
        private void init(Context context, AttributeSet attrs) {
            TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.TextDrawable);
            drawableLeft = typedArray.getDrawable(R.styleable.TextDrawable_leftDrawable);
            drawableRight = typedArray.getDrawable(R.styleable.TextDrawable_rightDrawable);
            drawableTop = typedArray.getDrawable(R.styleable.TextDrawable_topDrawable);
            if (drawableLeft != null) {
                leftWidth = typedArray.getDimensionPixelOffset(R.styleable.TextDrawable_leftDrawableWidth, dip2px(context, 20));
                leftHeight = typedArray.getDimensionPixelOffset(R.styleable.TextDrawable_leftDrawableHeight, dip2px(context, 20));
            }
            if (drawableRight != null) {
                rightWidth = typedArray.getDimensionPixelOffset(R.styleable.TextDrawable_rightDrawableWidth, dip2px(context, 20));
                rightHeight = typedArray.getDimensionPixelOffset(R.styleable.TextDrawable_rightDrawableHeight, dip2px(context, 20));
            }
            if (drawableTop != null) {
                topWidth = typedArray.getDimensionPixelOffset(R.styleable.TextDrawable_topDrawableWidth, dip2px(context, 20));
                topHeight = typedArray.getDimensionPixelOffset(R.styleable.TextDrawable_topDrawableHeight, dip2px(context, 20));
            }
        }
    
    
    public  int dip2px(Context context, float dpValue) 
      {    
    final float scale = context.getResources().getDisplayMetrics().density;    
    return (int) (dpValue * scale + 0.5f);
      }
    
        @Override
        protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
            super.onMeasure(widthMeasureSpec, heightMeasureSpec);
            if (drawableLeft != null) {
                drawableLeft.setBounds(0, 0, leftWidth, leftHeight);
            }
            if (drawableRight != null) {
                drawableRight.setBounds(0, 0, rightWidth, rightHeight);
            }
            if (drawableTop != null) {
                drawableTop.setBounds(0, 0, topWidth, topHeight);
            }
        }
    
        @Override
        protected void onDraw(Canvas canvas) {
            super.onDraw(canvas);
            this.setCompoundDrawables(drawableLeft, drawableTop, drawableRight, null);
    
        }
    
        /**
         * 设置左侧图片并重绘
         */
        public void setDrawableLeft(Drawable drawableLeft) {
            this.drawableLeft = drawableLeft;
            invalidate();
        }
    
        /**
         * 设置左侧图片并重绘
         */
        public void setDrawableLeft(int drawableLeftRes) {
            this.drawableLeft = mContext.getResources().getDrawable(drawableLeftRes);
            invalidate();
        }
    
        /**
         * 设置右侧图片并重绘
         */
        public void setDrawableRight(Drawable drawableRight) {
            this.drawableRight = drawableLeft;
            invalidate();
        }
    
        /**
         * 设置右侧图片并重绘
         */
        public void setDrawableRight(int drawableRightRes) {
            this.drawableRight = mContext.getResources().getDrawable(drawableRightRes);
            invalidate();
        }
    
        /**
         * 设置上部图片并重绘
         */
        public void setDrawable(Drawable drawableTop) {
            this.drawableTop = drawableTop;
            invalidate();
        }
    
        /**
         * 设置右侧图片并重绘
         */
        public void setDrawableTop(int drawableTopRes) {
            this.drawableTop = mContext.getResources().getDrawable(drawableTopRes);
            invalidate();
        }
    }
    

    附上attrs:

    <declare-styleable name="TextDrawable">
            <attr name="leftDrawable" format="reference"/>
            <attr name="leftDrawableWidth" format="dimension"/>
            <attr name="leftDrawableHeight" format="dimension"/>
            <attr name="rightDrawable" format="reference"/>
            <attr name="rightDrawableWidth"   format="dimension"/>
            <attr name="rightDrawableHeight" format="dimension"/>
            <attr name="topDrawable" format="reference"/>
            <attr name="topDrawableWidth" format="dimension"/>
            <attr name="topDrawableHeight" format="dimension"/>
        </declare-styleable>
    

    以上为全部代码

    相关文章

      网友评论

      • houtengzhi:使用你的代码会不停的打印view requestLayout() improperly called by android.widget.TextView
        cpu占用率也很高,不知道作者有没有遇到这个问题?
        赫丹:不要意思,,谢谢指正,犯了个低级失误,自定义属性忘了内存回收了 在init()最好添加typedArray.recycle();
      • 有酒和远方:求源码链接
      • JayDragon:做成开源库多好啊,直接compile
      • 33d90bb0b49b:DensityUtils和UIUtils这两个类的代码发我邮箱一份吧(327057487@qq.com
      • 33d90bb0b49b:大哥哥哥DensityUtils和UIUtils这两个类的代码都没贴出来呀
        赫丹:@33d90bb0b49b 代码更新了
      • 君临城的狮子:系统自带的TextView控件就有drawableLeft等一系列绘制图片资源到文本的四周方位的属性啊,
        为啥不用系统的,是有啥缺陷吗?
        8f3a42caf1ad:@赫丹 谢谢分享 ,不过距离可以控制 android:drawablePadding 通过这个。一直都这么用
        君临城的狮子: @赫丹 哦哦,你标题就说明了😂
        赫丹: 系统的不可以在布局中设置大小只能动态再Java代码中设置😃😃😃 @光影GG
      • wan7451:很有用

      本文标题:Android 优化布局(解决TextView drawable

      本文链接:https://www.haomeiwen.com/subject/xdiauttx.html