您好,登錄后才能下訂單哦!
小編給大家分享一下JAVA代碼如何設置selector不同狀態下的背景顏色,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
代碼實現Shape
代碼實現Selector
StateListDrawable與GradientDrawable 的運用
在Android開發中,我們時常會用到自定義drawable樣式,在drawable中設置shape樣式或是selector選擇器,但是有時如果一個xml中需要用到多個drawable樣式,并且里面設置的樣式只是有細微的差別改變,那么自定義多個drawable樣式會顯得比較臃腫,使得drawable的xml文件太多,管理麻煩,所以有時本星覺得可以在代碼中創建drawable。
StateListDrawable與GradientDrawable 的運用
java實現selector:
/** * 設置背景選擇器 * * @param pressedDraw * @param normalDraw * @return */ private StateListDrawable getSelector(Drawable normalDraw, Drawable pressedDraw) { StateListDrawable stateListDrawable = new StateListDrawable(); stateListDrawable.addState(new int[]{android.R.attr.state_selected}, pressedDraw); stateListDrawable.addState(new int[]{}, normalDraw); return stateListDrawable; }
這是在代碼中創建selector,創建的類型是StateListDrawable,可以通過addState()為selector添加狀態,但是要注意一點添加state時,是有順序的,stateListDrawable會先執行最新添加的state,如果不是該state,在執行下面的state,如果把大范圍的state放到前面添加,會導致直接執行大范圍的state,而不執行后面的state。此外,在添加state中,在state前添加“-”號,表示此state為false(例如:-android.R.attr.state_selected),否則為true。
/** * 設置shape * * @param radius * @param fillColor * @param width * @param strokeColor * @return */ private GradientDrawable getDrawable(int radius, int fillColor, int width, int strokeColor) { GradientDrawable gradientDrawable = new GradientDrawable(); gradientDrawable.setCornerRadius(radius); gradientDrawable.setColor(fillColor); gradientDrawable.setStroke(width, strokeColor); return gradientDrawable; }
在代碼中動態創建GradientDrawable ,可實現drawable樣式中shape樣式的功能,setColor等于shape中的填充色,setCornerRadius是設置shape中的圓角半徑,如果要設置單個角的弧度,可以用setCornerRadii()設置每個角的弧度,setStroke()是描邊,需要填寫描邊的寬和邊的顏色。
最后簡單使用:
GradientDrawable normal = getDrawable(0, Color.WHITE, 1, getResources().getColor(R.color.app_line_color)); GradientDrawable press = getDrawable(0, Color.WHITE, 1, getResources().getColor(Config.currentThemeColorId)); StateListDrawable selector = getSelector(normal, press); textView.setBackground(selector);
看完了這篇文章,相信你對“JAVA代碼如何設置selector不同狀態下的背景顏色”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。