MaterialDesign工具库,二维码生成、蛛网评分控件、权限申请、自定义Toas KilleTomRxMaterialDesignUtil

推荐理由:MaterialDesign工具库,二维码生成、蛛网评分控件、权限申请、自定义Toast、支持高斯模糊、图片选择等常用工具 KilleTomRxMaterialDesignUtil,依赖方式, 这个网站会告诉你有多少个版本以及你选择哪个版本进行依赖,多种依赖方式供你选择,运行效果图,Tables,Are,RaiseButton,RxToast,RxPermissions,RxAnneSeekBar,RxAnneSeekBa,RxHerculesQRCodeImageView,RxEthanSpiderWeb RxSpiderWebLayout,RxPhotoTools,RxCatherineBlur,RxEasyArcLoading,自定义RaiseButton,RxRaisedDropButton 、RxRai

适用人群:工具

推荐指数:26

项目名称:KilleTomRxMaterialDesignUtil

996station正文分割线=================================

KilleTomRxMaterialDesignUtil

依赖方式:JitPack | Publish JVM and Android libraries 这个网站会告诉你有多少个版本以及你选择哪个版本进行依赖,多种依赖方式供你选择

运行效果图

TablesAre
RaiseButtonRxToast
RxPermissionsRxAnneSeekBar
RxAnneSeekBa
RxHerculesQRCodeImageViewRxEthanSpiderWeb RxSpiderWebLayout
RxPhotoToolsRxCatherineBlur

RxEasyArcLoading

自定义RaiseButton

RxRaisedDropButton 、RxRaisedDropImageButton使用方式如下:

<style name="RxRaisedDropButtonPrimaryStyle" parent="Base.Widget.AppCompat.Button.Colored"> <item name="android:colorControlHighlight">#DA6954</item> <item name="android:colorControlNormal">@color/colorAccent</item> <item name="android:colorControlActivated">#DA8736</item> <item name="android:colorButtonNormal">@color/colorAccent</item> </style> <cn.ypz.com.killetomrxmateria.rxwidget.raisebutton.RxRaisedDropButton android:id="@+id/showtoast" android:layout_width="wrap_content" android:layout_height="wrap_content" android:theme="@style/RxRaisedDropPrimaryStyle" android:text="DIY has Ripper" android:layout_margin="10dp" android:layout_gravity="center_horizontal"/> <cn.ypz.com.killetomrxmateria.rxwidget.raisebutton.RxRaisedDropImageButton android:layout_width="60dp" android:layout_height="55dp" android:layout_gravity="center_horizontal" android:scaleType="centerInside" android:src="@drawable/ic_black_24dp" android:theme="@style/RxRaisedDropPrimaryStyle" android:layout_margin="10dp"/> `>

 

<!--声明style: -->

<style name="RxRaisedDropButtonPrimaryStyle" parent="Base.Widget.AppCompat.Button.Colored">

<!--设置点亮的动画颜色-->

<item name="android:colorControlHighlight">#DA6954</item>

<!--设置正常背景颜色颜色-->

<item name="android:colorControlNormal">@color/colorAccent</item>

<item name="android:colorControlActivated">#DA8736</item>

<item name="android:colorButtonNormal">@color/colorAccent</item>

</style>

<!--引用Theme: -->

<cn.ypz.com.killetomrxmateria.rxwidget.raisebutton.RxRaisedDropButton

android:id="@+id/showtoast"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:theme="@style/RxRaisedDropPrimaryStyle"

android:text="DIY has Ripper"

android:layout_margin="10dp"

android:layout_gravity="center_horizontal"/>

<cn.ypz.com.killetomrxmateria.rxwidget.raisebutton.RxRaisedDropImageButton

android:layout_width="60dp"

android:layout_height="55dp"

android:layout_gravity="center_horizontal"

android:scaleType="centerInside"

android:src="@drawable/ic_black_24dp"

android:theme="@style/RxRaisedDropPrimaryStyle"

android:layout_margin="10dp"/>

 

//如果不需要Z轴动画变化可以将Z轴设置0dp,调用方法如下:

public void setHeightLightEvetion(int dimenId){ mDelegate.setViewHeightLightElevation(dimenId); }

自定义Toast并支持链式调用

默认有5种模式如下

 

public enum RxToastType {

RxToastNormalType,//正常模式

RxToastSuccessType,//成功模式

RxToastErrorType,//错误模式

RxToastInfoType,//信息模式

RxToastWarningType//警告模式

}

调用分为两种模式:

直接调用返回一个Toast对象

 

//方法1设置显示信息以及显示类型

public static Toast choseType(RxToastType rxToastType, @NonNull Context context, @NonNull CharSequence message)

//方法2设置显示信息、显示时间以及显示类型

public static Toast choseType(RxToastType rxToastType, @NonNull Context context,@NonNull CharSequence message, int duration)

//方法3设置显示信息、显示时间、显示图标以及显示类型

public static Toast choseType(RxToastType rxToastType, @NonNull Context context, @NonNull CharSequence message, int duration, RxToastIcon toastImage)

//方法4设置显示信息、显示时间、显示图标、背景颜色以及显示类型

public static Toast custom(@NonNull Context context, @NonNull CharSequence charSequence, int duration, @ColorInt int bgColor, RxToastIcon toastImage)

//方法5设置显示信息、显示时间、显示图标、背景颜色、继承显示文本的文本动画以及显示类型

public static Toast custom(@NonNull Context context, @NonNull RxToastText text, int duration, @ColorInt int bgColor, RxToastIcon toastImage)

然后直接调用show方法即可显示

配置者模式调用config模式调用:

 

//初始化所有配置清单属性包括颜色、文字大小等属性

public static void reset()

//更改四大显示模式下对应的背景颜色

//错误模式下背景颜色

public Config setErrorColor(@ColorInt int errorColor)

//信息模式下背景颜色

public Config setInfoColor(@ColorInt int infoColor)

//成功模式下背景颜色

public Config setSuccessColor(@ColorInt int successColor)

//警告模式下背景颜色

public Config setWarningColor(@ColorInt int warningColor)

//设置字体的样式

public Config setToastTypeface(@NonNull Typeface typeface)

//设置字体大小

public Config setTextSize(int sizeInSp)

//设置是否显示绘制的图标

public Config tintIcon(boolean tintIcon)

//设置是否文字及图标启动动画

public Config setUseAnim(boolean useAnim)

//不需要过多的设置的情况下可以直接调用如下这一个方法

public Config show(RxToastType rxToastType, @NonNull Context context, @NonNull CharSequence message)

//最后调用Apply方法提交,apply后reset config默认属性,特殊情况下直接调用reset()方法回退属性设置

public void apply()

调用示列如下:

 

RxToast.choseType(RxToastType.RxToastErrorType,loginRegisterActivity, "Error").show()

RxToast.Config.getInstance().show(RxToastType.RxToastSuccessType, this, "成功").apply()

RxToast.Config.getInstance()

.setUseAnim(false)

.setErrorColor(resources.getColor(R.color.error_color_material))

.setTextColor(resources.getColor(R.color.red))

.setTextSize(15)

.apply()

权限模式简化申请:

 

分为带弹窗提示用户申请或直接让系统弹窗申请权限该两种模式都是最终会弹出系统申请权限弹窗。

带弹窗模式可以更直观的让用户知道该功能模块需要使用到什么权限,带权限弹窗支持自定义弹窗或者选择默认弹窗。

可选择继承RxPermissionBaseActivity重写方法处理相应的状态,不继承需要重写回调方法,requestCode值为1需要对它进行会调处理。

RxPermissionBaseActivity()重写方法如下

 

override fun permissionAllow() {

RxToast.Config.getInstance().show(RxToastType.RxToastSuccessType, this, "成功").apply()

}

override fun permissionRefuse() {

RxToast.Config.getInstance().show(RxToastType.RxToastWarningType, this, "取消权限部分授权").apply()

}

override fun requestCodeError(requestCode: Int) {

RxToast.Config.getInstance().show(RxToastType.RxToastErrorType, this, "取消授权").apply()

}

//然后这样使用:

private fun dialog() {

//弹窗代码示例

RxPermissions.with(this).initDialogPermission(

RxPermissions.Builder.RequestpermissionSelf { permissionAllow() },

RxPermissions.Builder.PermissionDialogCancle { permissionRefuse() },

RxPermissionEmpty(Manifest.permission.WRITE_EXTERNAL_STORAGE, "文件", R.mipmap.rx_permission_storage_icon),

RxPermissionEmpty(Manifest.permission.CAMERA, "相机", R.mipmap.rx_permission_camera_icon),

RxPermissionEmpty(Manifest.permission.READ_EXTERNAL_STORAGE, "文件", R.mipmap.rx_permission_storage_icon),

RxPermissionEmpty(Manifest.permission.CALL_PHONE, "电话", R.mipmap.rx_permission_phone_icon),

RxPermissionEmpty(Manifest.permission.READ_SMS, "短信", R.mipmap.rx_permission_sms_icon),

RxPermissionEmpty(Manifest.permission.SEND_SMS, "短信", R.mipmap.rx_permission_sms_icon)

).build()

}

private fun noDialog1() {

RxPermissions.with(this)

.addPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE)

.addPermission(Manifest.permission.CAMERA)

.initPermission { permissionAllow() }

}

//以下及以上两种不弹窗代码示例

private fun noDialog2() {

RxPermissions.with(this)

.baseNoDialogInitPerission(

RxPermissions.Builder.RequestpermissionSelf { permissionAllow() },

Manifest.permission.WRITE_EXTERNAL_STORAGE,

Manifest.permission.CAMERA,

Manifest.permission.CALL_PHONE

)

}

//不继承需要实现两个接口如下:

public interface RequestpermissionSelf {

void self();

}

public interface PermissionDialogCancle {

void cancle();

}

//然后这样编写:

private fun noDialog1() {

RxPermissions.with(this)

.addPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE)

.addPermission(Manifest.permission.CAMERA)

.initPermission { this.self() }

}

//以下及以上两种不弹窗代码示例

private fun noDialog2() {

RxPermissions.with(this)

.baseNoDialogInitPerission(

RxPermissions.Builder.RequestpermissionSelf { this.self() },

Manifest.permission.WRITE_EXTERNAL_STORAGE,

Manifest.permission.CAMERA,

Manifest.permission.CALL_PHONE

)

}

//弹窗代码示例

private fun dialog() {

RxPermissions.with(this).initDialogPermission(

RxPermissions.Builder.RequestpermissionSelf { this.self() },

RxPermissions.Builder.PermissionDialogCancle { this.cancle() },

RxPermissionEmpty(Manifest.permission.WRITE_EXTERNAL_STORAGE, "文件", R.mipmap.rx_permission_calendar_icon),

RxPermissionEmpty(Manifest.permission.CAMERA, "相机", R.mipmap.rx_permission_camera_icon),

RxPermissionEmpty(Manifest.permission.READ_EXTERNAL_STORAGE, "文件", R.mipmap.rx_permission_calendar_icon),

RxPermissionEmpty(Manifest.permission.CALL_PHONE, "电话", R.mipmap.rx_permission_camera_icon),

RxPermissionEmpty(Manifest.permission.READ_SMS, "短信", R.mipmap.rx_permission_calendar_icon),

RxPermissionEmpty(Manifest.permission.SEND_SMS, "短信", R.mipmap.rx_permission_camera_icon)

).build()

}

//权限结果回调判断

override fun onRequestPermissionsResult(requestCode: Int, permissions: Array<String>, grantResults: IntArray) {

super.onRequestPermissionsResult(requestCode, permissions, grantResults)

if (requestCode == 1)

if (grantResults.size > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED)

RxToast.Config.getInstance().show(RxToastType.RxToastSuccessType, this, "获取到权限了").apply()

else

RxToast.Config.getInstance().show(RxToastType.RxToastWarningType, this, "部分权限授权失败").apply()

else

RxToast.Config.getInstance().show(RxToastType.RxToastErrorType, this, "权限获取错误").apply()

}

RxAnneSeekBar部分示例

更多示例请去查阅代码源码也有注释讲解

 

anner1.max = 100F

anner1.progress = 11F

//手动设置进度及指示器相关颜色

anner1.setProgressColor(R.color.bisque)

anner1.setReadyColor(R.color.violet)

anner1.setThumbIndicatorColor(R.color.dimgray)

//设置平均分为四份长度

anner2.setAverage(3)

anne3.setExpandProgressMessage(rxAnnerExpandProgressMessage)

anne3.hideAnneToast()

nsv.setOnTouchListener(View.OnTouchListener { v, event ->

if (event.action == MotionEvent.ACTION_DOWN || event.action == MotionEvent.ACTION_MOVE) {

if (event.action == MotionEvent.ACTION_DOWN) {

X = event.x

Y = event.y

return@OnTouchListener false

}

}

return@OnTouchListener false

})

 

<--!"修改进度颜色及未完成进度颜色、指示器颜色" -->

<cn.ypz.com.killetomrxmateria.rxwidget.seekbar.RxAnneSeekBar

android:layout_width="wrap_content"

android:layout_height="wrap_content"

app:anneProgress="10"

app:anneProgressColor="@color/bisque"

app:anneReadyProgressColor="@color/violet"

app:anneThumbIndicatorColor="@color/dimgray" />

<--!"设置平均点n例如二分之则设置为1平均分为多少份就总份数减去一" -->

<cn.ypz.com.killetomrxmateria.rxwidget.seekbar.RxAnneSeekBar

android:layout_width="wrap_content"

android:layout_height="wrap_content"

app:anneAverage="2"

app:anneAverageIndicator="CircleIndicator"/>

<--!"圆角矩形指示器一" -->

<cn.ypz.com.killetomrxmateria.rxwidget.seekbar.RxAnneSeekBar

android:layout_width="wrap_content"

android:layout_height="wrap_content"

app:anneThumbIndicator="RoundedRectangleIndicator"/>

RxEthanSpiderWeb RxSpiderWebLayout部分示例

`>

 

<declare-styleable name="RxEthanSpiderWeb">

<attr name="maxScore" />

<attr name="hierarchyCount" />

<attr name="angleCount" />

<attr name="spiderStrokeWidth" />

<attr name="scoreStrokeWidth" />

<attr name="spiderStokeBg" />

<attr name="spiderBg" />

<attr name="spiderEndBg" />

<attr name="scoreBg" />

<attr name="scoreStokeBg" />

<attr name="isSpiderBg" />

<attr name="isScoreBg" />

<attr name="isSpiderStroke" />

<attr name="isScoreStroke" />

<attr name="isComplexOffset" />

<attr name="isGradientSpider" />

</declare-styleable>

<declare-styleable name="RxSpiderWebLayout">

<attr name="isBuildInSpider" format="boolean" />

<attr name="spiderMargin" format="dimension" />

<attr name="maxScore" />

<attr name="hierarchyCount" />

<attr name="angleCount" />

<attr name="spiderStrokeWidth" />

<attr name="scoreStrokeWidth" />

<attr name="spiderStokeBg" />

<attr name="spiderBg" />

<attr name="spiderEndBg" />

<attr name="scoreBg" />

<attr name="scoreStokeBg" />

<attr name="isSpiderBg" />

<attr name="isScoreBg" />

<attr name="isSpiderStroke" />

<attr name="isScoreStroke" />

<attr name="isComplexOffset" />

<attr name="isGradientSpider" />

</declare-styleable>

<!--大部分属性支持代码动态修改-->

<!--具体所有效果均在蛛网评分控件页面的代码上-->

RxHerculesQRCodeImageView 二维码部分示例

<declare-styleable name="RxHerculesQRCodeImageView"> <attr name="qrMode" format="integer"> <enum name="qrNormoal" value="0" /> <enum name="qrLogoCenter" value="1" /> <enum name="qrLogoBg" value="2"/> <enum name="qrLogoShape" value="3"/> </attr> <attr name="qrColor" format="color" /> <attr name="qrMessage" format="string" /> <attr name="qrLogo" format="reference" /> </declare-styleable> <cn.ypz.com.killetomrxmateria.rxwidget.qrcode.RxHerculesQRCodeImageView android:id="@+id/qr6" android:layout_width="150dp" android:layout_height="150dp" android:layout_marginTop="10dp" app:layout_constraintStart_toStartOf="@id/l1" app:layout_constraintTop_toBottomOf="@+id/qr5" android:background="@drawable/qrlogoshape" app:qrMessage="https://blog.youkuaiyun.com/qq_29856589/article/details/80311907" app:qrMode="qrLogoShape" />`>

 

<!--二维码自定义属性-->

<declare-styleable name="RxHerculesQRCodeImageView">

<attr name="qrMode" format="integer">

<enum name="qrNormoal" value="0" />

<enum name="qrLogoCenter" value="1" />

<enum name="qrLogoBg" value="2"/>

<enum name="qrLogoShape" value="3"/>

</attr>

<attr name="qrColor" format="color" />

<attr name="qrMessage" format="string" />

<attr name="qrLogo" format="reference" />

</declare-styleable>

<!--渐变模式下xml使用方式,其余方式参考示例页面xml文件即可-->

<cn.ypz.com.killetomrxmateria.rxwidget.qrcode.RxHerculesQRCodeImageView

android:id="@+id/qr6"

android:layout_width="150dp"

android:layout_height="150dp"

android:layout_marginTop="10dp"

app:layout_constraintStart_toStartOf="@id/l1"

app:layout_constraintTop_toBottomOf="@+id/qr5"

android:background="@drawable/qrlogoshape"

app:qrMessage="https://blog.youkuaiyun.com/qq_29856589/article/details/80311907"

app:qrMode="qrLogoShape" />

RxPhotoTools图片选择示例

使用它可以简化图片申请代码处理回调结果即可

 

class PhotoActivity : RxPhotoActivity() {

override fun photoUri(uri: Uri?) {

textView.text = "图片uri信息是:"+uri.toString()

Log.i("ypz",uri.toString())

}

override fun onCreate(savedInstanceState: Bundle?) {

super.onCreate(savedInstanceState)

setContentView(R.layout.activity_photo)

show.setOnClickListener {

if (chosePhotoDialog!=null) chosePhotoDialog.show()

else{

chosePhotoDialog = ChosePhotoDialog(this, cn.ypz.com.killetomrxmateria.R.style.ChosePhotoDialog,null)

chosePhotoDialog.show()

}

}

}

}

//不想继承可以参考 RxPhotoActivity() 中的代码避免忘记权限申请导致出错

BaseActivity

支持两种沉侵式设置 使用方法继承它然后调用transgressionStatusBarWindow()或者transgressionAllWindow()即可

RxCatherineBlur

高斯模糊使用了缩放预处理加快高斯模糊的生成 支持链式调用如下:

 

//radius 模糊值

//scale 图片预处理宽高缩放多少

//OriginalBtimap 原图Bitmap

//blueWay 支持常用两种模糊方式默认为RenderScript如果使用默认方式则不用链式调用blueWay()

f_bluer.setImageBitmap(RxCatherineBlur.Config.getInstance(this).

OriginalBtimap(BitmapFactory.decodeResource(resources, R.mipmap.qrlogo2)).

scale(0.75f).blueWay(RxCatherineBlur.BlueWay.FastBlur).radius(25).apply())

亦可支持新建对象设置属性调用

 

public void setOriginalBtimap(Bitmap originalBtimap) {

this.originalBtimap = originalBtimap;

if (scale > 0 && scale < 1) scale();

}

public RxCatherineBlur(Context context) {

this.context = context;

}

public Context getContext() {

return context;

}

public void setScale(float scale) {

if (scale <= 0 || scale > 1) scale = 0.75f;

this.scale = scale;

if (originalBtimap != null) scale();

}

private void scale() {

scaleBtimap = Bitmap.createScaledBitmap(

originalBtimap,

(int) (originalBtimap.getWidth() * scale),

(int) (originalBtimap.getHeight() * scale),

false);

}

public void setRadius(int radius) {

if (radius > 25 || radius < 0) radius = 10;

this.radius = radius;

}

public Bitmap blur(BlueWay blueWay,Bitmap originalBtimap,int radius,float scale) {

setOriginalBtimap(originalBtimap);

setRadius(radius);

setScale(scale);

return blur(blueWay);

}

public Bitmap blur(BlueWay blueWay){

if (blueWay == BlueWay.RenderScript)

return rsBlur();

else return fBlur();

}

开源地址

https://github.com/KilleTom/KilleTomRxMaterialDesignUtil

开源是一种精神,致敬屏幕背后的你

=================================

原文链接:MaterialDesign工具库,二维码生成、蛛网评分控件、权限申请、自定义Toas KilleTomRxMaterialDesignUtil - 996station | 996技术站

更多精彩内容,就在996技术站-996station,极客带你看世界!

转载请注明出处!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值