RGB HSV HLS三种色彩模式转换(C语言实现)
Android项目上处理图像的代码(注释全部去掉)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
|
void RGB2HSV( uint16_t * h, uint16_t * s, uint16_t * v, uint8_t r, uint8_t g, uint8_t b) { double rr, gg, bb; double hh, ss, vv; double cmax, cmin, cdes; rr = r; gg = g; bb = b; cmax = (rr > gg) ? rr : gg; if (bb > cmax) { cmax = bb; } cmin = (rr < gg) ? rr : gg; if (bb < cmin) { cmin = bb; } cdes = cmax - cmin; vv = cmax; if (cdes != 0) { ss = cdes * SCALE / cmax; if (cmax == rr) { hh = (gg - bb) * SCALE / cdes; } else if (cmax == gg) { hh = (bb - rr) * SCALE / cdes + 2 * H_SCALE; } else { hh = (rr - gg) * SCALE / cdes + 4 * H_SCALE; } } else if (cmax != 0) { ss = cdes * SCALE / cmax; hh = 0; } else { ss = 0; hh = 0; } if (hh < 0) { hh += 6 * H_SCALE; } *h = hh * H_GETA; *s = ss * H_GETA; *v = vv * H_GETA; } void HSV2RGB( uint8_t *r, uint8_t *g, uint8_t *b, uint16_t h, uint16_t s, uint16_t v) { double rr = 0, gg = 0, bb = 0; double hh, ss, vv; if (h == 6 * H_GETA * H_SCALE) { h = 0; } hh = ( double )h / H_GETA; ss = ( double )s / GETA; vv = ( double )v / GETA; switch (( int )(hh / H_SCALE)) { case 0: rr = SCALE; gg = hh; bb = 0; break ; case 1: rr = 2 * H_SCALE - hh; gg = SCALE; bb = 0; break ; case 2: rr = 0; gg = SCALE; bb = hh - 2 * H_SCALE; break ; case 3: rr = 0; gg = 4 * H_SCALE - hh; bb = SCALE; break ; case 4: rr = hh - 4 * H_SCALE; gg = 0; bb = SCALE; break ; case 5: rr = SCALE; gg = 0; bb = 6 * H_SCALE - hh; break ; } rr = (rr + (SCALE - rr) * (SCALE - ss) / SCALE) * vv / SCALE; gg = (gg + (SCALE - gg) * (SCALE - ss) / SCALE) * vv / SCALE; bb = (bb + (SCALE - bb) * (SCALE - ss) / SCALE) * vv / SCALE; *r = rr; *g = gg; *b = bb; if (*r > 255)*r = 255; if (*g > 255)*g = 255; if (*b > 255)*b = 255; } void RGB2HLS( double *h, double *l, double *s, uint8_t r, uint8_t g, uint8_t b) { double dr = ( double )r/255; double dg = ( double )g/255; double db = ( double )b/255; double cmax = MAX(dr, MAX(dg, db)); double cmin = MIN(dr, MIN(dg, db)); double cdes = cmax - cmin; double hh, ll, ss; ll = (cmax+cmin)/2; if (cdes){ if (ll <= 0.5) ss = (cmax-cmin)/(cmax+cmin); else ss = (cmax-cmin)/(2-cmax-cmin); if (cmax == dr) hh = (0+(dg-db)/cdes)*60; else if (cmax == dg) hh = (2+(db-dr)/cdes)*60; else // if(cmax == b) hh = (4+(dr-dg)/cdes)*60; if (hh<0) hh+=360; } else hh = ss = 0; *h = hh; *l = ll; *s = ss; } void HLS2RGB( uint8_t *r, uint8_t *g, uint8_t *b, double h, double l, double s) { double cmax,cmin; if (l <= 0.5) cmax = l*(1+s); else cmax = l*(1-s)+s; cmin = 2*l-cmax; if (s == 0){ *r = *g = *b = l*255; } else { *r = HLS2RGBvalue(cmin,cmax,h+120)*255; *g = HLS2RGBvalue(cmin,cmax,h)*255; *b = HLS2RGBvalue(cmin,cmax,h-120)*255; } } double HLS2RGBvalue( double n1, double n2, double hue) { if (hue > 360) hue -= 360; else if (hue < 0) hue += 360; if (hue < 60) return n1+(n2-n1)*hue/60; else if (hue < 180) return n2; else if (hue < 240) return n1+(n2-n1)*(240-hue)/60; else return n1; } |
RGB HSV HLS三种色彩模式转换(C语言实现)的更多相关文章
- 执行Go程序的三种方式及Go语言关键字
执行 Go 程序的三种方式及 Go 语言关键字 执行 Go 程序的三种方式 一.使用 go run 命令 二.使用 go build 命令 Step1. 对 go 源码源文件执行 go build 命 ...
- Java程序员的现代RPC指南(Windows版预编译好的Protoc支持C++,Java,Python三种最常用的语言,Thrift则支持几乎主流的各种语言)
Java程序员的现代RPC指南 1.前言 1.1 RPC框架简介 最早接触RPC还是初学Java时,直接用Socket API传东西好麻烦.于是发现了JDK直接支持的RMI,然后就用得不亦乐乎,各种大 ...
- PHP,JavaScript,CSS三种HTML内嵌语言的语法,变量,循环,函数记录
PHP PHP简介: PHP 是服务器端脚本语言. PHP(全称:PHP:Hypertext Preprocessor,即"PHP:超文本预处理器")是一种通用开源脚本语言. PH ...
- hibernate 增改查后对象的三种状态转换
this.getSession().update(obj); this.getSession().merge(obj); this.getSession().saveOrUpdate(obj);1. ...
- 低功耗蓝牙UUID三种格式转换
熟悉BLE技术同学应该对UUID不陌生,服务.特征值.描述都是有UUID格式定义. 蓝牙广播中对服务UUID格式定义都有三种16 bit UUID.32 bit UUID.128 bit UUID. ...
- 计算2的n次方的三种方法(C语言实现)
C代码如下: #include <stdio.h> int func1(int n) { <<n; } int func2(int n) { ) { ; } )*; } int ...
- ASP.NET MVC:多语言的三种技术处理策略
ASP.NET MVC:多语言的三种技术处理策略 背景 本文介绍了多语言的三种技术处理策略,每种策略对应一种场景,这三种场景是: 多语言资源信息只被.NET使用. 多语言资源信息只被Javascrip ...
- 三种方式解决你的js加载乱码
第一种方式——编码统一 我们以前觉得出现乱码的原因是因为编码不统一,就是因为我们设置编码统一之后,就解决了问题,所以,让html和js的编码统一,是最简单的一个乱码解决方式,原因是什么,是因为,如果你 ...
- hibernate 三种状态的转换
一.遇到的神奇的事情 使用jpa操作数据库,当我使用findAll()方法查处一个List的对象后,给对这个list的实体进行了一些操作,并没有调用update 或者 saveOrUpdate方法,更 ...
随机推荐
- android getDecorView()的作用
decorView是window中的最顶层view,可以从window中通过getDecorView获取到decorView.通过decorView获取到程序显示的区域,包括标题栏,但不包括状态栏.间 ...
- C#委托好处知多少
1.性能 性能是泛型的一个主要优点. 直接上例子,通过实例可以让我们很好的理解这一点. Stopwatch stopwatch = new Stopwatch(); stopwatch.Start() ...
- android的animator
3.0 以前,android支持两种动画模式,tween animation,frame animation,在android3.0中又引入了一个新的动画系统:property animation,这 ...
- 打开sa属性报错
--如果打开sa属性报错如下:无法显示请求的对话框.属性IsLocked不可用于“登录名sa".该对象可能没有此属性,也可能是访问权限不足而无法检索 --解决办法:首先用windows登录, ...
- ACM第二次比赛( C )
Time Limit:1000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u Description Vanya ...
- jsp截取字符串
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn"%> < ...
- zookeeper 分布式应用好处
<pre name="code" class="html"> 举个例子 比如我以前通过haproxy 负载两台tomcat8082 比如api01 ...
- Boost学习之可移植路径操作--filesystem
Boost.Filesystem 库为对路径.文件和目录进行查询和操作提供了可移植的工具,已经被C++标准委员会接纳包含到TR2中. 编译 使用Boost.Filesystem 库之前要先编译它,请参 ...
- poll系统调用的内核态实现机制分析
版权所有,转载请标明出处 All right reserved,Copyright by 徐行而至 浅唱而归 前面已经比较详尽的分析了系统调用引发的内核执行过程,本文将继续分析一下linux2.6 ...
- MFC 只启动一个程序实例
问题描述: 我们开发过程中可能会经常遇到,只启动一个程序实例.即一个程序启动之后,如果再次执行该程序,将会恢复之前打开的程序,而不是打开一个新的程序. 实现原理:利用FindWindow/FindWi ...