【干货】基于iconfont拓展的EasyTextView(高度自定义,丰富Api,支持左右设置Text,设置Shape,设置span等)

EasyTextView是一款基于iconfont的TextView组件,支持链式调用,简化布局嵌套,提供便捷的文字与图标设置功能,适用于Android应用开发。

基于iconfont拓展的TextView(支持左右设置Text,设置Shape,设置span等)

项目介绍

  • 还在苦于iconfont左右两边还需要设置文字只能加两个TextView?
  • 还在苦于需要设置各种大同小异的边框而new Shape文件吗?
  • 还在苦于设置点击效果而多种样式吗?
  • 还在苦于总用LinearLayout包一层?(代码洁癖患者~)。
    一个基于iconfont拓展的支持多种功能的轻量级TextView,减少布局嵌套,减少定义shape文件,基本涵盖常规需要多个TextView实现的功能。

支持的特性

  • 使用简单
  • 链式调用
  • 支持给iconfont左右设置文字
  • 支持xml中直接设置常用shape的所有属性
  • 支持分别设置iconfont,左文字,右文字的颜色(Selector也可以)
  • 支持分别设置iconfont,左文字,右文字字号
  • 支持文字和iconfont居中
  • 支持左右文字设置多个span
  • 支持设置iconfont和左右文字的padding
  • 丰富的api,所有属性都支持xml和java调用

源码地址

EasyTextView

欢迎提issues和PR

Download

Step1

Add it in your root build.gradle at the end of repositories:

allprojects {
        repositories {
            ...
            maven { url 'https://jitpack.io' }
        }
    }
Step2

Step 2. Add the dependency

dependencies {
        implementation 'com.github.DrownCoder:EasyTextView:v1.0'
    }

效果

只有想不到没有做不到

使用

xml属性
<com.study.xuan.library.widget.EasyTextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="&#xe627;"
            android:textColor="#494949"
            android:textSize="14dp"
            app:iconColor="@android:color/holo_red_light"
            app:strokeColor="@android:color/holo_red_light"
            app:strokeWidth="1dp"
            app:textPadding="5dp"
            app:textRight="关注"
            app:totalRadius="12dp" />
<declare-styleable name="EasyTextView">
        //Shape中的Type:RECTANGLE:0(默认),OVAL(1),LINE(2)
        <attr name="shapeType" format="integer" />
        //四个角的圆角
        <attr name="totalRadius"  format="dimension"/>
        //左上角
        <attr name="radiusTopLeft" format="dimension"/>
        //左下角
        <attr name="radiusBottomLeft" format="dimension"/>
        //右上角
        <attr name="radiusTopRight" format="dimension"/>
        //右下角
        <attr name="radiusBottomRight" format="dimension"/>
        //边线的颜色
        <attr name="strokeColor"  format="color"/>
        //边线的宽度
        <attr name="strokeWidth" format="dimension" />
        //填充的颜色
        <attr name="soildBac" format="color"/>
        //中间的iconfont距离左右Text的内边距
        <attr name="textPadding" format="dimension"/>
        //左边的文字
        <attr name="textLeft" format="string"/>
        //右边的文字
        <attr name="textRight" format="string"/>
        //中间的iconfont的color(注意TextColor属性会覆盖)
        <attr name="iconColor" format="reference|color"/>
        //左边文字的color(注意TextColor属性会覆盖)
        <attr name="textLeftColor" format="reference|color"/>
        //右边文字的color(注意TextColor属性会覆盖)
        <attr name="textRightColor" format="reference|color"/>
        //左边文字的大小(iconfont的大小用TextSize即可,不会覆盖)
        <attr name="textLeftSize" format="dimension"/>
        //右边文字的大小(iconfont的大小用TextSize即可,不会覆盖)
        <attr name="textRightSize" format="dimension"/>
    </declare-styleable>
java Api
//少属性可以直接设置
etvGet.setTextRight(已关注);
//多属性可以链式调用,减少重复绘制,节省性能,注意最后build()
etvGet.strokeWidth(DensityUtils.dp2px(context, 1))
                    .strokeColor(Color.parseColor("#ffe849"))
                    .solid(Color.parseColor("#e8264a"))
                    .icon(context.getText(R.string.icon_font_check).toString())
                    .textRight("关注").build();
/**
  * 非链式调用api
  */
public void setType(int type);
public void setStrokeWidth(int value);
public void setStrokeColor(@ColorInt int color);
public void setSolid(int soild);
public void setIconColor(int color);
public void setTextLeft(CharSequence textLeft);
public void setTextRight(CharSequence textRight);
public void setTextLeftColor(int color);
public void setTextRightColor(int color);
public void setTextLeftSize(float leftSize);
public void setTextRightSize(float rightSize);
public void setIcon(String iconText);
public void clearSpan();
public void addSpanLeft(Object object, int start, int end, int flags);
public void addSpanLeft(List<Object> objects, int start, int end, int flags);
public void addSpanRight(List<Object> objects, int start, int end, int flags);
public void addSpanRight(Object object, int start, int end, int flags);
More

动态设置Shape,由SupperShape实现,可以动态通过java代码给任何View设置Shape,不需要再写shape.xml文件,欢迎使用。
本项目仅基于TextView进行封装,其他View可按照需求进行封装,原理比较简单,大家可以查看源码。
 
详细使用说明参考Wiki

在 Apache FtpServer 中,`WritePermission` 类用于控制用户是否拥有写入权限,但其本身并不提供对上传、删除、重命名等具体操作的细粒度控制。要实现这些权限的单独设置,需要结合 Apache FtpServer 的权限管理机制,通过自定义 `Authority` 类型来实现。 ### 使用 `WritePermission` 控制写权限 默认情况下,`WritePermission` 仅提供一个全局的写权限开关,通过 `setEnabled(boolean)` 方法控制用户是否可以执行所有写操作,包括上传、删除和重命名等。如果需要更细粒度的控制,需要扩展权限体系。 ```java import org.apache.ftpserver.usermanager.impl.WritePermission; WritePermission writePermission = new WritePermission(); writePermission.setEnabled(true); // 启用全部写权限 ``` 此设置将允许用户执行所有写操作,但无法单独控制上传、删除或重命名等功能[^1]。 ### 自定义权限类实现细粒度控制 要实现对上传、删除、重命名等操作的独立控制,可以通过实现 `org.apache.ftpserver.ftplet.Authority` 接口并定义多个自定义权限类。例如: ```java public class UploadPermission implements Authority { @Override public boolean canUpload() { return true; } @Override public boolean canDownload() { return true; } @Override public boolean canDelete() { return false; } @Override public boolean canRename() { return false; } // 实现其他方法 } ``` 通过为每个操作定义独立的权限类,可以在用户配置中动态添加或移除这些权限,从而实现细粒度的访问控制。 ### 动态配置用户权限 在用户配置中,可以通过 `BaseUser` 对象将这些自定义权限添加到用户权限列表中: ```java import org.apache.ftpserver.usermanager.impl.BaseUser; BaseUser user = new BaseUser(); user.setName("testuser"); user.setPassword("testpass"); user.setHomeDirectory("/home/testuser"); // 添加上传权限 user.getAuthorities().add(new UploadPermission()); ``` 该方法允许为每个用户分配特定权限,例如仅允许上传但不允许删除或重命名文件。 ### 权限配置的持久化 Apache FtpServer 支持将用户权限配置持久化到文件或数据库中。通过 `UserManager` 接口可以将用户配置保存到指定的存储位置: ```java UserManager userManager = ftpServer.getUserManager(); userManager.save(user); // 保存用户权限设置 ``` 此操作确保权限配置在服务器重启后仍然有效。 ### 权限验证与执行 在 FTP 服务器处理上传、删除、重命名等操作时,会检查用户是否拥有相应的权限。例如,在执行文件重命名操作时,服务器会调用 `canRename()` 方法验证权限: ```java if (user.hasAuthority(new RenamePermission())) { // 允许重命名操作 } else { // 拒绝操作 } ``` 通过这种方式,可以确保用户只能执行被授权的操作。 ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值