溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

在Android中icon+控件實(shí)現(xiàn)文字的多種效果

發(fā)布時(shí)間:2020-11-20 16:05:56 來源:億速云 閱讀:226 作者:Leah 欄目:移動(dòng)開發(fā)

這篇文章給大家介紹在Android中icon+控件實(shí)現(xiàn)文字的多種效果,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

第一步 自定義屬性  

在res/values/目錄下新建attrs.xml文件,
添加如下屬性

<attr name="backColor" format="color" />
 <attr name="backColorPress" format="color" />
 <attr name="textColor" format="color" />
 <attr name="textColorPress" format="color" />

 <declare-styleable name="ButtonExtendM">
  <attr name="backColor"/>
  <attr name="backColorPress"/>
  <attr name="textColor"/>
  <attr name="textColorPress"/>
  <attr name="iconDrawable" format="reference" />
  <attr name="iconDrawablePress" format="reference" />
  <attr name="text" format="string" />
  <attr name="textSize" format="float" />
  <attr name="spacing" format="dimension" />
  <attr name="style">
   <enum name="iconLeft" value="0" />
   <enum name="iconRight" value="1" />
   <enum name="iconUp" value="2" />
   <enum name="iconBottom" value="3" />
  </attr>
 </declare-styleable>

第二步 新建布局文件view_button_extend_m.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content">

 <ImageView
  android:id="@+id/iv_icon"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"/>

 <TextView
  android:id="@+id/tv_content"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:visibility="gone"
  android:text="@string/button_extend_m_default_text"/>

</RelativeLayout>

第三步 新建ButtonExtendM.java繼承RelativeLayout

package com.landptf.view;

import android.content.Context;
import android.content.res.ColorStateList;
import android.content.res.TypedArray;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.widget.ImageView;
import android.widget.RelativeLayout;
import android.widget.TextView;

import com.landptf.R;
import com.landptf.util.ConvertM;

/**
 * Created by landptf on 2016/10/31.
 * 擴(kuò)展Button,支持文字和icon分上下左右四種方式顯示
 * 默認(rèn)為左右結(jié)構(gòu),圖片在左,文字在右
 */
public class ButtonExtendM extends RelativeLayout {
 /**
  * 左右結(jié)構(gòu),圖片在左,文字在右
  */
 public static final int STYLE_ICON_LEFT = 0;
 /**
  * 左右結(jié)構(gòu),圖片在右,文字在左
  */
 public static final int STYLE_ICON_RIGHT = 1;
 /**
  * 上下結(jié)構(gòu),圖片在上,文字在下
  */
 public static final int STYLE_ICON_UP = 2;
 /**
  * 上下結(jié)構(gòu),圖片在下,文字在上
  */
 public static final int STYLE_ICON_DOWN = 3;

 /**
  * 定義控件
  */
 private ImageView ivIcon;
 private TextView tvContent;
 /**
  * 上下文
  */
 private Context mContext;
 /**
  * View的背景色
  */
 private int backColor = 0;
 /**
  * View被按下時(shí)的背景色
  */
 private int backColorPress = 0;
 /**
  * icon的背景圖片
  */
 private Drawable iconDrawable = null;
 /**
  * icon被按下時(shí)顯示的背景圖片
  */
 private Drawable iconDrawablePress = null;
 /**
  * View文字的顏色
  */
 private ColorStateList textColor = null;
 /**
  * View被按下時(shí)文字的顏色
  */
 private ColorStateList textColorPress = null;
 /**
  * 兩個(gè)控件之間的間距,默認(rèn)為8dp
  */
 private int spacing = 8;
 /**
  * 兩個(gè)控件的位置結(jié)構(gòu)
  */
 private int mStyle = STYLE_ICON_LEFT;
 /**
  * 標(biāo)示onTouch方法的返回值,用來解決onClick和onTouch沖突問題
  */
 private boolean isCost = true;

 private OnClickListener onClickListener = null;

 public interface OnClickListener {
  void onClick(View v);
 }

 /**
  * 設(shè)置View的Click事件
  *
  * @param l
  */
 public void setOnClickListener(OnClickListener l) {
  this.onClickListener = l;
  isCost = false;
 }

 public ButtonExtendM(Context context) {
  super(context);
  mContext = context;
 }

 public ButtonExtendM(Context context, AttributeSet attrs) {
  this(context, attrs, 0);
 }

 public ButtonExtendM(Context context, AttributeSet attrs, int defStyle) {
  super(context, attrs, defStyle);
  mContext = context;
  init(context, attrs, defStyle);

 }

 private void init(Context context, AttributeSet attrs, int defStyle) {
  //加載布局
  LayoutInflater.from(context).inflate(R.layout.view_button_extend_m, this, true);
  //初始化控件
  ivIcon = (ImageView) findViewById(R.id.iv_icon);
  tvContent = (TextView) findViewById(R.id.tv_content);
  setGravity(Gravity.CENTER);
  TypedArray a = getContext().obtainStyledAttributes(
    attrs, R.styleable.ButtonExtendM, defStyle, 0);
  if (a != null) {
   //設(shè)置背景色
   ColorStateList colorList = a.getColorStateList(R.styleable.ButtonExtendM_backColor);
   if (colorList != null) {
    backColor = colorList.getColorForState(getDrawableState(), 0);
    if (backColor != 0) {
     setBackgroundColor(backColor);
    }
   }
   //記錄View被按下時(shí)的背景色
   ColorStateList colorListPress = a.getColorStateList(R.styleable.ButtonExtendM_backColorPress);
   if (colorListPress != null) {
    backColorPress = colorListPress.getColorForState(getDrawableState(), 0);
   }
   //設(shè)置icon
   iconDrawable = a.getDrawable(R.styleable.ButtonExtendM_iconDrawable);
   if (iconDrawable != null) {
    ivIcon.setImageDrawable(iconDrawable);
   }
   //記錄View被按下時(shí)的icon的圖片
   iconDrawablePress = a.getDrawable(R.styleable.ButtonExtendM_iconDrawablePress);
   //設(shè)置文字的顏色
   textColor = a.getColorStateList(R.styleable.ButtonExtendM_textColor);
   if (textColor != null) {
    tvContent.setTextColor(textColor);
   }
   //記錄View被按下時(shí)文字的顏色
   textColorPress = a.getColorStateList(R.styleable.ButtonExtendM_textColorPress);
   //設(shè)置顯示的文本內(nèi)容
   String text = a.getString(R.styleable.ButtonExtendM_text);
   if (text != null) {
    //默認(rèn)為隱藏的,設(shè)置文字后顯示出來
    tvContent.setVisibility(VISIBLE);
    tvContent.setText(text);
   }
   //設(shè)置文本字體大小
   float textSize = a.getFloat(R.styleable.ButtonExtendM_textSize, 0);
   if (textSize != 0) {
    tvContent.setTextSize(textSize);
   }
   //設(shè)置兩個(gè)控件之間的間距
   spacing = a.getDimensionPixelSize(R.styleable.ButtonExtendM_spacing, ConvertM.dp2px(context, 8));
   //設(shè)置兩個(gè)控件的位置結(jié)構(gòu)
   mStyle = a.getInt(R.styleable.ButtonExtendM_style, 0);
   setIconStyle(mStyle);
   a.recycle();
  }

  setOnTouchListener(new OnTouchListener() {
   @Override
   public boolean onTouch(View arg0, MotionEvent event) {
    //根據(jù)touch事件設(shè)置按下抬起的樣式
    return setTouchStyle(event.getAction());
   }
  });

  setOnClickListener(new View.OnClickListener() {
   @Override
   public void onClick(View v) {
    if (onClickListener != null) {
     onClickListener.onClick(v);
    }
   }
  });
 }

 /**
  * 根據(jù)按下或者抬起來改變背景和文字樣式
  *
  * @param state
  * @return isCost
  */
 private boolean setTouchStyle(int state) {
  if (state == MotionEvent.ACTION_DOWN) {
   if (backColorPress != 0) {
    setBackgroundColor(backColorPress);
   }
   if (iconDrawablePress != null) {
    ivIcon.setImageDrawable(iconDrawablePress);
   }
   if (textColorPress != null) {
    tvContent.setTextColor(textColorPress);
   }
  }
  if (state == MotionEvent.ACTION_UP) {
   if (backColor != 0) {
    setBackgroundColor(backColor);
   }
   if (iconDrawable != null) {
    ivIcon.setImageDrawable(iconDrawable);
   }
   if (textColor != null) {
    tvContent.setTextColor(textColor);
   }
  }
  return isCost;
 }

 /**
  * 設(shè)置圖標(biāo)位置
  * 通過重置LayoutParams來設(shè)置兩個(gè)控件的擺放位置
  * @param style
  */
 public void setIconStyle(int style) {
  mStyle = style;
  RelativeLayout.LayoutParams lp;
  switch (style) {
   case STYLE_ICON_LEFT:
    lp = new RelativeLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
    lp.addRule(RelativeLayout.CENTER_VERTICAL);
    ivIcon.setLayoutParams(lp);
    lp = new RelativeLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
    lp.addRule(RelativeLayout.CENTER_VERTICAL);
    lp.addRule(RelativeLayout.RIGHT_OF, ivIcon.getId());
    lp.leftMargin = spacing;
    tvContent.setLayoutParams(lp);
    break;
   case STYLE_ICON_RIGHT:
    lp = new RelativeLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
    lp.addRule(RelativeLayout.CENTER_VERTICAL);
    tvContent.setLayoutParams(lp);
    lp = new RelativeLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
    lp.addRule(RelativeLayout.CENTER_VERTICAL);
    lp.addRule(RelativeLayout.RIGHT_OF, tvContent.getId());
    lp.leftMargin = spacing;
    ivIcon.setLayoutParams(lp);
    break;
   case STYLE_ICON_UP:
    lp = new RelativeLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
    lp.addRule(RelativeLayout.CENTER_HORIZONTAL);
    ivIcon.setLayoutParams(lp);
    lp = new RelativeLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
    lp.addRule(RelativeLayout.CENTER_HORIZONTAL);
    lp.addRule(RelativeLayout.BELOW, ivIcon.getId());
    lp.leftMargin = spacing;
    tvContent.setLayoutParams(lp);
    break;
   case STYLE_ICON_DOWN:
    lp = new RelativeLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
    lp.addRule(RelativeLayout.CENTER_HORIZONTAL);
    tvContent.setLayoutParams(lp);
    lp = new RelativeLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
    lp.addRule(RelativeLayout.CENTER_HORIZONTAL);
    lp.addRule(RelativeLayout.BELOW, tvContent.getId());
    lp.leftMargin = spacing;
    ivIcon.setLayoutParams(lp);
    break;
   default:
    break;
  }
 }

 /**
  * 設(shè)置View的背景色
  *
  * @param backColor
  */
 public void setBackColor(int backColor) {
  this.backColor = backColor;
  setBackgroundColor(backColor);
 }

 /**
  * 設(shè)置View被按下時(shí)的背景色
  *
  * @param backColorPress
  */
 public void setBackColorPress(int backColorPress) {
  this.backColorPress = backColorPress;
 }

 /**
  * 設(shè)置icon的圖片
  *
  * @param iconDrawable
  */
 public void setIconDrawable(Drawable iconDrawable) {
  this.iconDrawable = iconDrawable;
  ivIcon.setImageDrawable(iconDrawable);
 }

 /**
  * 設(shè)置View被按下時(shí)的icon的圖片
  *
  * @param iconDrawablePress
  */
 public void setIconDrawablePress(Drawable iconDrawablePress) {
  this.iconDrawablePress = iconDrawablePress;
 }

 /**
  * 設(shè)置文字的顏色
  *
  * @param textColor
  */
 public void setTextColor(int textColor) {
  if (textColor == 0) return;
  this.textColor = ColorStateList.valueOf(textColor);
  tvContent.setTextColor(this.textColor);
 }

 /**
  * 設(shè)置View被按下時(shí)文字的顏色
  *
  * @param textColorPress
  */
 public void setTextColorPress(int textColorPress) {
  if (textColorPress == 0) return;
  this.textColorPress = ColorStateList.valueOf(textColorPress);
 }

 /**
  * 設(shè)置顯示的文本內(nèi)容
  *
  * @param text
  */
 public void setText(CharSequence text) {
  //默認(rèn)為隱藏的,設(shè)置文字后顯示出來
  tvContent.setVisibility(VISIBLE);
  tvContent.setText(text);
 }

 /**
  * 獲取顯示的文本
  *
  * @return
  */
 public String getText() {
  return tvContent.getText().toString();
 }

 /**
  * 設(shè)置文本字體大小
  *
  * @param size
  */
 public void setTextSize(float size) {
  tvContent.setTextSize(size);
 }

 /**
  * 設(shè)置兩個(gè)控件之間的間距
  *
  * @param spacing
  */
 public void setSpacing(int spacing) {
  this.spacing = ConvertM.dp2px(mContext, spacing);
  //設(shè)置完成后刷新一下兩個(gè)控件的結(jié)構(gòu),避免先執(zhí)行了setIconStyle后,setSpacing不生效
  setIconStyle(mStyle);
 }

}

代碼注釋基本可以看懂具體的實(shí)現(xiàn),接下來主要看下如何使用

在layout里直接引用ButtonExtendM即可,注意要添加

xmlns:landptf="http://schemas.android.com/apk/res-auto"

<com.landptf.view.ButtonExtendM
 android:id="@+id/bem_back"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_centerVertical="true"
 android:layout_marginLeft="8dp"
 landptf:iconDrawable="@drawable/title_back"
 landptf:iconDrawablePress="@drawable/title_back_selected"
 landptf:textColor="@android:color/white"
 landptf:spacing="4dp"
 landptf:text="返回"/>

這個(gè)是實(shí)現(xiàn)的菜單欄的返回按鈕,左右結(jié)構(gòu),icon在左為默認(rèn)樣式,注意一下*Press的屬性,主要是用來設(shè)置控件被按下后的效果的。

再來看一個(gè)上下結(jié)構(gòu)的

<com.landptf.view.ButtonExtendM
 android:layout_width="0dp"
 android:layout_height="match_parent"
 android:layout_weight="1"
 landptf:iconDrawable="@drawable/icon_home_page"
 landptf:text="首頁"
 landptf: />

只需要設(shè)置landptf:style即可,同時(shí)也可以通過java代碼實(shí)現(xiàn)

setIconStyle(ButtonExtendM.STYLE_ICON_UP)

關(guān)于在Android中icon+控件實(shí)現(xiàn)文字的多種效果就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI