All Projects → liujinchao → Xselectorutil

liujinchao / Xselectorutil

一个可以用代码处理控件的阴影效果,及用代码在TextView、EditText、Button等控件设置selector背景(触摸反馈,样式变化、文字颜色变化、hint文字颜色变化等效果)的组件

Programming Languages

java
68154 projects - #9 most used programming language

Projects that are alternatives of or similar to Xselectorutil

ShadowDrawable
为View 和 ViewGroup 添加阴影效果--Android,Add shadow for single view or viewgroup layout.
Stars: ✭ 22 (-77.55%)
Mutual labels:  background, shadow
android-multibackground
This library can easily apply round corner、stroke、shadow and different state effects to background drawable.
Stars: ✭ 18 (-81.63%)
Mutual labels:  background, shadow
Xamarin.forms.backgroundkit
🔨 A powerful Kit for customizing the background of Xamarin.Forms views
Stars: ✭ 167 (+70.41%)
Mutual labels:  background, shadow
Rwidgethelper
Android UI 快速开发,专治原生控件各种不服
Stars: ✭ 996 (+916.33%)
Mutual labels:  selector, shadow
Lowpoly
Lowpoly image generator
Stars: ✭ 83 (-15.31%)
Mutual labels:  background
Reapex
A lightweight framework to build pluggable and extendable redux/react application
Stars: ✭ 58 (-40.82%)
Mutual labels:  selector
Real Shadow
Module that casts photorealistic shadows
Stars: ✭ 1,066 (+987.76%)
Mutual labels:  shadow
React Propers
Select react doms , and update props.
Stars: ✭ 40 (-59.18%)
Mutual labels:  selector
Sketch Make Long Shadow
A plugin for Sketch to create long shadows of a user defined length from a shape.
Stars: ✭ 92 (-6.12%)
Mutual labels:  shadow
Resq
React Element Selector Query (RESQ) - Query React components and children by component name or HTML selector
Stars: ✭ 89 (-9.18%)
Mutual labels:  selector
Himawari Bg
🌏 Set the latest image from Himawari 8 as your desktop background.
Stars: ✭ 81 (-17.35%)
Mutual labels:  background
React Native Modal Dropdown
A react-native dropdown/picker/selector component for both Android & iOS.
Stars: ✭ 1,103 (+1025.51%)
Mutual labels:  selector
Statebutton
一个可以用代码设置selector背景(按下去背景颜色更改,样式变化等等)的button, 再也不用写selector了
Stars: ✭ 1,276 (+1202.04%)
Mutual labels:  selector
Shadowsocksx Ng R8
ShadowsocksX-NG-R for MacOS, ShadowsocksR
Stars: ✭ 1,066 (+987.76%)
Mutual labels:  shadow
Shapeview
A customized shape view with shadow and transparent background supported.
Stars: ✭ 90 (-8.16%)
Mutual labels:  shadow
Uiutil
UIUtil for Android, Lyrics, Tick animations, Comparisons, Satellite menus, Praise, Slide buttons, TAB indicators, Contact sorting, Drag sorting, Skidding deletes, Shadow effects, RecyclerView nesting RecyclerView, Map list Poi/Drawer effects, Progress settings, Clock set, Damping, Progress, Album, Snap, Progress, CircleDownload, AdvertSwitcher, Carousel ad, FlowLayout, Tag...; 歌词控件、打勾动画、对比、卫星菜单、点赞、滑动按钮、TAB指示器、联系人排序、拖曳排序、侧滑删除、阴影效果.、RecyclerView嵌套RecyclerView.、地图列表Poi/抽屉效果、进度设置、时钟设置、滑动阻尼、相册媒体快照、圆形下载进度,轮播广告, 流式布局,标签...
Stars: ✭ 1,018 (+938.78%)
Mutual labels:  shadow
Postcss Prefix Selector
Prefix all CSS rules with a selector
Stars: ✭ 75 (-23.47%)
Mutual labels:  selector
Ishadow
Creating a beautiful iOS style shadow [Sketch Plugin]
Stars: ✭ 89 (-9.18%)
Mutual labels:  shadow
Css Vars Ponyfill
Client-side support for CSS custom properties (aka "CSS variables") in legacy and modern browsers
Stars: ✭ 1,166 (+1089.8%)
Mutual labels:  shadow
Vanta
Animated 3D backgrounds for your website
Stars: ✭ 1,162 (+1085.71%)
Mutual labels:  background

XSelectorUtil

一个可以用代码在TextView、EditText、Button等控件设置selector背景(触摸反馈,样式变化、文字颜色变化、hint文字颜色变化等效果)的组件,新增了ShadowHelper帮助控件实现阴影效果。

目的: XSelector工具旨在解决项目中selector.xml文件随着需求的增加不断增多的问题,创造一个可以用代码在TextView、EditText、Button等控件设置selector背景(触摸反馈,样式变化、文字颜色变化、hint文字颜色变化等效果)的组件, 再也不用写selector.xml了,瞬间感觉好爽歪歪啊,如若感觉对你还有帮助,希望star一下。

先来看下XSelector能实现哪些效果,如下图所示(包含图中样式但不限于这些样式哦):

xselector演示图

XSelector如何使用

把工具类引入到项目中:compile 'com.android.util:xselector:1.0.3'

初始化:

在Application中进行初始化: XSelector.init(this);

工具相关使用方法

  1. ShapeSelector

    • 圆形边框
      TextView tv_oval_line = (TextView) findViewById(R.id.tv_oval_line);
      XSelector.shapeSelector()
              .setShape(GradientDrawable.OVAL)
              .defaultBgColor(R.color.colorAccent)
              .defaultStrokeColor(R.color.colorAccent)
              .strokeWidth(1)
              .into(tv_oval_line);
      
    • 方形虚线圆角边框
        TextView tv_rect_dash_line_radius = (TextView)findViewById(R.id.tv_rect_dash_line_radius);
        XSelector.shapeSelector()
                .setShape(GradientDrawable.RECTANGLE)
                .defaultBgColor(R.color.colorAccent)
                .dashLine(1, R.color.colorPrimary, 5, 5)
                .radius(5)
                .into(tv_rect_dash_line_radius);
      
         TextView tv_rect_diagonal2 =  (TextView)findViewById(R.id.tv_rect_diagonal2);
         XSelector.shapeSelector()
                .setShape(GradientDrawable.RECTANGLE)
                .defaultBgColor(R.color.colorAccent)
                .trRadius(10)
                .blRadius(10)
                .into(tv_rect_diagonal2);
      
    • 触摸反馈
       TextView tv_oval_solid = (TextView) findViewById(R.id.tv_oval_solid);
       XSelector.shapeSelector()
               .setShape(GradientDrawable.OVAL)
               .defaultBgColor(R.color.colorAccent)
               .pressedBgColor(R.color.colorPrimary)
               .into(tv_oval_solid);
               
       ImageView img1 = (ImageView) findViewById(R.id.img1);
       XSelector.shapeSelector()
              .setShape(GradientDrawable.OVAL)
              .defaultBgColor(R.color.colorAccent)
              .pressedBgColor(R.color.defaultColor)
              .into(img1);
      
    • 渐变效果
        TextView tv_gradient_linear_tb =  (TextView)findViewById(R.id.tv_gradient_linear_tb);
        XSelector.shapeSelector()
                .setShape(GradientDrawable.RECTANGLE)
                .gradientLinear(ShapeSelector.TOP_BOTTOM, R.color.colorAccent, R.color.colorPrimary)
                .into(tv_gradient_linear_tb);
      
        TextView tv_gradient_sweep =  (TextView)findViewById(R.id.tv_gradient_sweep);
        XSelector.shapeSelector()
                .setShape(GradientDrawable.OVAL)
                .gradientSweep(R.color.colorAccent, R.color.colorPrimary)
                .into(tv_gradient_sweep);
      
        TextView tv_gradient_radial =  (TextView)findViewById(R.id.tv_gradient_radial);
        XSelector.shapeSelector()
                .setShape(GradientDrawable.OVAL)
                .gradientRadial(30, R.color.colorAccent, R.color.colorPrimary)
                .into(tv_gradient_radial);
                
      

    详细方法名如下:

    方法名 描述
    setShape(@Shape int shape) 边框背景形状
    defaultBgColor/disabledBgColor 默认背景颜色
    disabledBgColor 不可点击背景色
    pressedBgColor 触摸背景色
    selectedBgColor 选中背景色
    focusedBgColor 获取焦点背景色
    strokeWidth 边框宽度
    defaultStrokeColor 默认边框颜色
    disabledStrokeColor 不可点击边框背景色
    pressedStrokeColor 触摸边框背景色
    selectedStrokeColor 选中边框背景色
    focusedStrokeColor 获取焦点边框背景色
    dashLine 边框虚线样式
    gradient 渐变样式
    gradientLinear 线性渐变样式
    gradientSweep 扫描渐变样式
    gradientRadial 辐射渐变样式
    radius 设置圆角弧度
    trRadius/tlRadius/brRadius/blRadius 设置右上圆角/左上/右下/左下
    build 生成样式Drawable
    into 填充目标View

  2. ColorSelector和DrawableSelector

    • 作用在TextView

      XSelector.colorSelector()
             .defaultColor(R.color.black)
             .selectedColor(R.color.yellow)
             .disabledColor(R.color.gray)
             .into(tv4);
      
    • 作用在EditText

      //作用在setTextColor
      XSelector.colorSelector()
             .defaultColor(R.color.gray)
             .focusedColor(R.color.black)
             .into(et1);
      //作用在setHintTextColor
      XSelector.colorSelector()
             .defaultColor(R.color.gray)
             .focusedColor(R.color.white)
             .textType(ColorSelector.HINT_TEXT_COLOR)
             .into(et1);
      
    • 作用在Button

      XSelector.drawableSelector()
             .defaultDrawable(R.mipmap.blue_primary)
             .pressedDrawable(R.mipmap.blue_primary_dark)
             .into(btn1);
      
    • 作用在ImageView

      XSelector.drawableSelector()
            .defaultDrawable(R.mipmap.blue_primary)
            .pressedDrawable(R.mipmap.blue_primary_dark)
            .into(img1);
      

    使用方法存在但不限于上述使用方法,具体详细方法如下:

    模块 方法名 描述
    ColorSelector defaultColor 默认颜色
    disabledColor 不可点击
    pressedColor 触摸
    selectedColor 选中
    focusedColor 获取焦点
    textType 设置类型:TextColor(默认)、HintTextColor
    build 状态集合ColorStateList
    into 目标View
    DrawableSelector defaultDrawable 默认
    disabledDrawable 不可点击
    pressedDrawable 触摸
    selectedDrawable 选中
    focusedDrawable 获取焦点
    build 背景Drawable
    into 目标View

  3. ShadowHelper

    阴影效果

    使用方法:

       XSelector.shadowHelper().setShape(ShadowHelper.SHAPE_CIRCLE)
           .setBgColor(Color.parseColor("#FF3D00"))
           .setShapeRadius(dpToPx(6))
           .setShadowColor(Color.parseColor("#991DE9B6"))
           .setShadowRadius(dpToPx(6))
           .setOffsetX(dpToPx(4))
           .setOffsetY(dpToPx(4))
           .into(textView5);
    
    

    使用方法存在但不限于上述使用方法,具体详细方法如下:

    模块 方法名 描述
    shadowHelper setShape 设置背景形状,椭圆或者圆形
    setBgColor 背景颜色
    setShapeRadius 设置背景半径
    setShadeSide 设置阴影方向,默认四周
    setShadeRadius 设置阴影半径
    setShadowColor 设置阴影颜色
    setOffsetX 设置阴影X轴偏移量
    setOffsetY 设置阴影Y轴偏移量
    setShadowAlpha 设置阴影透明度
    into 目标View
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].