Android 仿PhotoShop调色板应用(四) 不同区域颜色选择的颜色生成响应
版权声明:本文为博主原创文章,未经博主允许不得转载。
Android 仿PhotoShop调色板应用(四) 不同区域颜色选择的颜色生成响应
上一篇讲过了主体界面的绘制,这里讲解调色板应用中的另外一个核心: 颜色选择及生成.
ColorPcikerView中不同部分的选择和ColorPickerPanelView中颜色显示是怎样响应的呢?这里当然少不了回调函数:
ColorPickerView:
- public interface OnColorChangedListener {
- public void onColorChanged(int color);
- }
然后看一下轨迹球的事件处理:
- @Override
- public boolean onTrackballEvent(MotionEvent event) {
- float x = event.getX();
- float y = event.getY();
- boolean update = false;//是否需要更新颜色
- if(event.getAction() == MotionEvent.ACTION_MOVE){
- switch(mLastTouchedPanel){
- case PANEL_SAT_VAL://饱和度&亮度选择区域
- float sat, val;
- sat = mSat + x/50f;
- val = mVal - y/50f;
- if(sat < 0f){
- sat = 0f;
- }
- else if(sat > 1f){
- sat = 1f;
- }
- if(val < 0f){
- val = 0f;
- }
- else if(val > 1f){
- val = 1f;
- }
- mSat = sat;
- mVal = val;
- update = true;
- break;
- case PANEL_HUE://色相选择区域
- float hue = mHue - y * 10f;
- if(hue < 0f){
- hue = 0f;
- }
- else if(hue > 360f){
- hue = 360f;
- }
- mHue = hue;
- update = true;
- break;
- case PANEL_ALPHA://透明度选择区域
- if(!mShowAlphaPanel || mAlphaRect == null){
- update = false;
- }
- else{
- int alpha = (int) (mAlpha - x*10);
- if(alpha < 0){
- alpha = 0;
- }
- else if(alpha > 0xff){
- alpha = 0xff;
- }
- mAlpha = alpha;
- update = true;
- }
- break;
- }
- }
- if(update){//如果需要更新,调用对用的回调函数并重新绘制
- if(mListener != null){//参数需要由HSV格式的float数组转换为ARGB格式的 int 参数
- mListener.onColorChanged(Color.HSVToColor(mAlpha, new float[]{mHue, mSat, mVal}));
- }
- invalidate();
- return true;
- }
- return super.onTrackballEvent(event);
- }
ColorPickerView中关于触摸事件的处理:
- @Override
- public boolean onTouchEvent(MotionEvent event) {
- boolean update = false;
- switch(event.getAction()){
- case MotionEvent.ACTION_DOWN:
- mStartTouchPoint = new Point((int)event.getX(), (int)event.getY());
- update = moveTrackersIfNeeded(event);
- break;
- case MotionEvent.ACTION_MOVE:
- update = moveTrackersIfNeeded(event);
- break;
- case MotionEvent.ACTION_UP:
- mStartTouchPoint = null;
- update = moveTrackersIfNeeded(event);
- break;
- }
- if(update){
- if(mListener != null){
- mListener.onColorChanged(Color.HSVToColor(mAlpha, new float[]{mHue, mSat, mVal}));
- }
- invalidate();
- return true;
- }
- return super.onTouchEvent(event);
- }
- //判断是否触发事件,更新区域颜色
- private boolean moveTrackersIfNeeded(MotionEvent event){
- if(mStartTouchPoint == null) return false;
- boolean update = false;
- //获取触摸点X,Y坐标值
- int startX = mStartTouchPoint.x;
- int startY = mStartTouchPoint.y;
- //判断 X,Y坐标是否在对应的区域内,并做相应的处理
- if(mHueRect.contains(startX, startY)){
- mLastTouchedPanel = PANEL_HUE;
- mHue = pointToHue(event.getY());
- update = true;
- }
- else if(mSatValRect.contains(startX, startY)){
- mLastTouchedPanel = PANEL_SAT_VAL;
- float[] result = pointToSatVal(event.getX(), event.getY());
- mSat = result[0];
- mVal = result[1];
- update = true;
- }
- else if(mAlphaRect != null && mAlphaRect.contains(startX, startY)){
- mLastTouchedPanel = PANEL_ALPHA;
- mAlpha = pointToAlpha((int)event.getX());
- update = true;
- }
- return update;
- }
使用时,让ColorPickerDialog实现ColorPickerView.OnColorChangedListener接口:
并完成对应方法:
- @Override
- public void onColorChanged(int color) {
- mNewColor.setColor(color);// mNewColor即为右下角实时显示颜色的ColorPickerPanelView
- if (mHexValueEnabled)
- updateHexValue(color);
- /*
- if (mListener != null) {
- mListener.onColorChanged(color);
- }
- */
- }
- private void updateHexValue(int color) {
- if (getAlphaSliderVisible()) {
- mHexVal.setText(ColorPickerPreference.convertToARGB(color).toUpperCase(Locale.getDefault()));
- } else {
- mHexVal.setText(ColorPickerPreference.convertToRGB(color).toUpperCase(Locale.getDefault()));
- }
- mHexVal.setTextColor(mHexDefaultTextColor);
- /** 转化为ARGB格式字符串
- * For custom purposes. Not used by ColorPickerPreferrence
- * @param color
- * @author Unknown
- */
- public static String convertToARGB(int color) {
- String alpha = Integer.toHexString(Color.alpha(color));
- String red = Integer.toHexString(Color.red(color));
- String green = Integer.toHexString(Color.green(color));
- String blue = Integer.toHexString(Color.blue(color));
- if (alpha.length() == 1) {
- alpha = "0" + alpha;
- }
- if (red.length() == 1) {
- red = "0" + red;
- }
- if (green.length() == 1) {
- green = "0" + green;
- }
- if (blue.length() == 1) {
- blue = "0" + blue;
- }
- return "#" + alpha + red + green + blue;
- }
最后看一下ColorPickerPanelView点击后的颜色设置事件处理:
- @Override
- public void onClick(View v) {
- if (v.getId() == R.id.new_color_panel) {
- if (mListener != null) {
- mListener.onColorChanged(mNewColor.getColor());
- }
- }
- dismiss();
- }
注意一下,这里的OnColorChangedListener是在ColorPickerDialog中定义的:
- private OnColorChangedListener mListener;
- ublic interface OnColorChangedListener {
- public void onColorChanged(int color);
最终的颜色是怎么显示到ColorPickerPreference上呢,其实实现的方法是一样的:
- implements ColorPickerDialog.OnColorChangedListener
在ColorPickerPreference中实现对应的回调方法:
- @Override
- public void onColorChanged(int color) {
- if (isPersistent()) {
- persistInt(color);
- }
- mValue = color;
- setPreviewColor();
- try {
- getOnPreferenceChangeListener().onPreferenceChange(this, color);
- } catch (NullPointerException e) {
- }
- }
调用setPreviewColor()改变ColorPickerPreference中颜色区域的显示:
- private void setPreviewColor() {
- if (mView == null) return;
- ImageView iView = new ImageView(getContext());
- LinearLayout widgetFrameView = ((LinearLayout)mView.findViewById(android.R.id.widget_frame));
- if (widgetFrameView == null) return;
- widgetFrameView.setVisibility(View.VISIBLE);
- widgetFrameView.setPadding(
- widgetFrameView.getPaddingLeft(),
- widgetFrameView.getPaddingTop(),
- (int)(mDensity * 8),
- widgetFrameView.getPaddingBottom()
- );
- // remove already create preview image
- int count = widgetFrameView.getChildCount();
- if (count > 0) {
- widgetFrameView.removeViews(0, count);
- }
- widgetFrameView.addView(iView);
- widgetFrameView.setMinimumWidth(0);
- iView.setBackgroundDrawable(new AlphaPatternDrawable((int)(5 * mDensity)));
- iView.setImageBitmap(getPreviewBitmap());
- }
最后调用getOnPreferenceChangeListener().onPreferenceChange(this, color);改变颜色设置值
然后在下次打开ColorPickerDialog时,传入上面onColorChanged()回调实现中已经改变的mValue参数
- mDialog = new ColorPickerDialog(getContext(), mValue);
至此,PS调色板应用中颜色交互的事件讲解完毕.
相信当分析完PhotoShop调色板应用后,大家会对颜色渲染方面会有一个认识上的提高.
Android 仿PhotoShop调色板应用(四) 不同区域颜色选择的颜色生成响应的更多相关文章
- Android 仿PhotoShop调色板应用(三) 主体界面绘制
版权声明:本文为博主原创文章,未经博主允许不得转载. Android 仿PhotoShop调色板应用(三) 主体界面绘制 关于PhotoShop调色板应用的实现我总结了两个最核心的部分: 1 ...
- Android 仿PhotoShop调色板应用(二) 透明度绘制之AlphaPatternDrawable
版权声明:本文为博主原创文章,未经博主允许不得转载. Android 仿PhotoShop调色板应用(二) 透明度绘制之AlphaPatternDrawable 这里讲一下如何实现PS调色板中的透明度 ...
- Android 仿PhotoShop调色板应用(一)概述
版权声明:本文为博主原创文章,未经博主允许不得转载. 在前面的系列我已经将Android中颜色渲染的原理及使用做了一个整体上概述. 现在开始根据一个比较复杂的实现进行具体的分析,这就是PhotoSho ...
- Android仿人人客户端(v5.7.1)——个人主页(三)
转载请标明出处:http://blog.csdn.net/android_ls/article/details/9405089 声明:仿人人项目,所用所有图片资源都来源于其它Android移动应用,编 ...
- Android仿人人客户端(v5.7.1)——新鲜事之完整篇
转载请标明出处: http://blog.csdn.net/android_ls/article/details/9228083 声明:仿人人项目,所用所有图片资源都来源于其它Androi ...
- Android OpenGL ES(十四)gl10方法解析
Android 支持 OpenGL 列表 1.GL 2.GL 10 3.GL 10 EXT 4.GL 11 5.GL 11 EXT 6.GL 11 ExtensionPack 我们将使用 GL10 这 ...
- Android 仿知乎创意广告
代码地址如下:http://www.demodashi.com/demo/14904.html 一.概述 貌似前段时间刷知乎看到的一种非常有特色的广告展现方式,即在列表页,某一个Item显示背后部分广 ...
- Android仿微信图片上传,可以选择多张图片,缩放预览,拍照上传等
仿照微信,朋友圈分享图片功能 .可以进行图片的多张选择,拍照添加图片,以及进行图片的预览,预览时可以进行缩放,并且可以删除选中状态的图片 .很不错的源码,大家有需要可以下载看看 . 微信 微信 微信 ...
- android仿漫画源码、抽奖转盘、Google相册、动画源码等
Android精选源码 android实现仿今日头条的开源项目 波浪效果,实现流量的动态显示 美妆领域的app, 集成了摄像头取色, 朋友圈, 滤镜等 android仿漫画源码 android一个视差 ...
随机推荐
- 简单学c——前言
1.学C语言需要什么基础吗? 零基础. 2.什么是C语言? C语言是一种编程语言. 3.什么是编程语言? 编程语言是用来定义计算机程序的形式语言,是一种被标准化的交流技巧,用来向计算机发出指令. ...
- 学习Swift -- 协议(下)
协议(下) 在拓展中添加协议成员 通过扩展使得Dice类型遵循了一个新的协议,这和Dice类型在定义的时候声明为遵循TextRepresentable协议的效果相同.在扩展的时候,协议名称写在类型名之 ...
- Mac、Linux与Windows
Mac本身是基于达尔文内核(Darwin内核),是苹果由UNIX改造的类UNIX,然后在这内核基础上搭建的图形界面 Linux确实是个好东西,你只需要一个键盘,一个显示器,一根网线,接入网络,便能做几 ...
- 区分html与css中的属性
CSS中id与Class的区别 1.在CSS文件里书写时,ID加前缀"#":CLASS用"." 2.id一个页面只可以使用一次:class可以多次引用. 3.I ...
- 设置表格td超出内容后截取并以...显示
.ellipsis { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } <table style=" ...
- Contest20140906 反思
这次考试最大的失误就是把最简单的一道题RE了,原因是我在main()函数中开了一个2^19的数组,这种做法在linux下没有任何问题,然而放到windows下评测,就会出现栈溢出的错误. 单题总结: ...
- BZOJ 4011 开店
Description 风见幽香有一个好朋友叫八云紫,她们经常一起看星星看月亮从诗词歌赋谈到人生哲学.最近她们灵机一动,打算在幻想乡开一家小店来做生意赚点钱.这样的想法当然非常好啦,但是她们也发现她们 ...
- 开启Eclipse 智能感知代码功能
1.打开windows->Perferences..窗口,选择java->Editor->Content Assist,在右下方的“Auto Activation triggers ...
- MySQL数据库事务隔离级别(Transaction Isolation Level)
转自: http://www.cnblogs.com/zemliu/archive/2012/06/17/2552301.html 数据库隔离级别有四种,应用<高性能mysql>一书中的 ...
- scanf(),fscanf的详解
我们这里只讨论fscanf(或者scanf)的格式,因为这些细节在其他贴里并没有涉及,阅读此文,你可以少走一些弯路.只讲结果,深层原因并不分析. FILE *pFile:float x1; char ...