Android颜色编辑器的制作中遇到的问题分析

所属分类: 软件编程 / Android 阅读数: 977
收藏 0 赞 0 分享
Android没有自带颜色编辑器,为了让用户直观的选择颜色,做了这么一个控件,效果图如下:



上方颜色条为主颜色条,用户可以选择大致需要的颜色,下方是该颜色的平衡调节,可以调节明亮度。

背景颜色实现起来很容易,用GradientDrawable在主色之间分段渐变即可,上方的背景色是永远不变的。下方平衡调节只要在白色、选定色和黑色之间渐变即可,下方的颜色随着上方的颜色变化而变化。

颜色条自身控件由于需要拖动,直接集成Android自带的SeekBar就能实现,只需替换默认的ProgressDrawable即可。

唯一遇到的一个奇怪问题是:

我为下方的颜色调提供了一个颜色数组:

复制代码 代码如下:

private int[] colorArr;


里面存放:白色、上方选定色和黑色
当上方选定色更改后,我改变colorArr数组中的第二个颜色,即选定色,并调用控件的invalidate方法,奇怪的是控件并没有改变颜色,还是原来的颜色。

此时,如果拖动下方的滚动条,哪怕只拖动1%,也能改变成正确的颜色。
我就猜测:Android的SeekBar在进度没有改变的时候,是不会重绘它的进度背景色的。
于是使用以下技巧,人为的改变到某个进度,再改回来,这样就能重绘它的进度背景色了:

复制代码 代码如下:

/**
* 设置颜色平衡的中间色
* @param color
*/
public void SetBalenceColor(int color)
{
this.color = color;
SetBackground();//重新设置ProgressDrawable中的中间色
//this.invalidate();
int max = this.getMax();
int currentProgress = this.getProgress(); //备份进度
this.setProgress(max - currentProgress);//修改到其他某个进度
this.setProgress(currentProgress);//还原进度
}
更多精彩内容其他人还在看

Android studio点击跳转WebView详解

这篇文章主要为大家详细介绍了Android studio点击跳转WebView的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android自定义Drawable实现圆形和圆角

这篇文章主要为大家详细介绍了Android自定义Drawable实现圆形和圆角,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android自定义水平渐变进度条

这篇文章主要为大家详细介绍了Android自定义水平渐变进度条,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

ToolBar中menu无法同时显示图标和文字问题的解决方法

这篇文章主要为大家详细介绍了ToolBar中menu无法同时显示图标和文字问题的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

详解React Native监听Android回退按键与程序化退出应用

这篇文章主要介绍了详解React Native监听Android回退按键与程序化退出应用的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
收藏 0 赞 0 分享

android实现上传本地图片到网络功能

这篇文章主要为大家详细介绍了android实现上传本地图片到网络功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android实现QQ登录功能

这篇文章主要为大家详细介绍了Android实现QQ登录功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android实现简单的城市列表功能

这篇文章主要为大家详细介绍了Android实现简单的城市列表功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android Animation之TranslateAnimation(平移动画)

这篇文章主要为大家详细介绍了Animation之TranslateAnimation平移动画,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android 中Failed to read key from keystore解决办法

这篇文章主要介绍了Android 中Failed to read key from keystore解决办法的相关资料,希望通过本能帮助到大家,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多