如何用简单的算法生成一个类似『光盘』的彩色圆形图片?
程序员文章站
2022-03-28 15:48:49
...
大概就像下图所示的样子
基本上就是在这个圆上颜色的色相(Hue),只与该点与圆心连线的夹角有关。知道这一点你就做一幅图像,然后遍历每一个点,把该点的坐标值转换为极坐标,色相值就是极坐标角度。
用 matplotlib 实现的话有个小技巧,把imshow的cmap改为hsv就可以直接按照色相来画。
关于色相是什么(反正这里说的不是可以用来牺牲的那个色相了),可以参看Wiki:HSL和HSV色彩空间,那个H就是色相Hue。
有点像下面这幅图的横截面(摘自Wiki)
只不过明度Chroma没有变化。
这样的话,蛮简单的啊。对每个像素算出它所在半径的角度 0~2π 然后映射到Hue的值域上就是了。
具体实现的话,话说可以用OpenCV吗?反正一些图像库里面是有HSR到RGB的转换函数的。
(我一直都不明白所谓邀请是怎么回事,以及为什么大家都爱说谢邀) 补充一下Mathematica代码
回复内容:
补充一下MATLAB的代码:t = (0:.02:2)*pi;
r = 0:.02:1;
pcolor(cos(t)'*r,sin(t)'*r,t'*(r==r))
colormap(hsv(256)), shading interp, axis image off
...被抢先了...基本上就是在这个圆上颜色的色相(Hue),只与该点与圆心连线的夹角有关。知道这一点你就做一幅图像,然后遍历每一个点,把该点的坐标值转换为极坐标,色相值就是极坐标角度。
用 matplotlib 实现的话有个小技巧,把imshow的cmap改为hsv就可以直接按照色相来画。
# -*- coding:utf-8 -*-
from pylab import *
center = (250, 250)
radius = 250
img = zeros((500,500))
for i in range(500):
for j in range(500):
x = i - center[0] * 1.0
y = j - center[1] * 1.0
if x**2+y**2 radius**2:
if x > 0:
img[i,j] = arctan(y/x)
elif x0 and y>=0:
img[i,j] = arctan(y/x) + pi
elif x0 and y0:
img[i,j] = arctan(y/x) - pi
elif x==0 and y>0:
img[i,j] = pi / 2
elif x==0 and y0:
img[i,j] = pi / -2
elif x==0 and y==0:
img[i,j] = 0.0
print img
imshow(img, cmap=cm.hsv)
show()
改编自@冯昱尧的代码from pylab import *
n=300
img=[[arctan2(x,y) if x*x+y*yn*n else 0 for y in range(-n,n)] for x in range(-n,n)]
imshow(img, cmap=cm.hsv)
show()
如果根据这幅图,“光盘”的意思就是每一条半径的颜色在色相Hue上渐变。关于色相是什么(反正这里说的不是可以用来牺牲的那个色相了),可以参看Wiki:HSL和HSV色彩空间,那个H就是色相Hue。
有点像下面这幅图的横截面(摘自Wiki)
只不过明度Chroma没有变化。
这样的话,蛮简单的啊。对每个像素算出它所在半径的角度 0~2π 然后映射到Hue的值域上就是了。
具体实现的话,话说可以用OpenCV吗?反正一些图像库里面是有HSR到RGB的转换函数的。
(我一直都不明白所谓邀请是怎么回事,以及为什么大家都爱说谢邀) 补充一下Mathematica代码
n=300;
c=Hue[i/n];
Graphics@Table[{c,EdgeForm@c,Disk[{0,0},1,2Pi/n{i-1,i}]},{i,n}]
期待mma的代码,估计一条语句搞定声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
相关文章
相关视频
专题推荐
-
独孤九贱-php全栈开发教程
全栈 170W+
主讲:Peter-Zhu 轻松幽默、简短易学,非常适合PHP学习入门
-
玉女心经-web前端开发教程
入门 80W+
主讲:灭绝师太 由浅入深、明快简洁,非常适合前端学习入门
-
天龙八部-实战开发教程
实战 120W+
主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习
网友评论
文明上网理性发言,请遵守 新闻评论服务协议
我要评论