当前位置:首页 » 操作系统 » 颜色识别算法

颜色识别算法

发布时间: 2022-12-13 16:08:26

① 用python写识别图片主要颜色的程序

#-*-coding:utf-8-*-

importcolorsys

defget_dominant_color(image):

#颜色模式转换,以便输出rgb颜色值
image=image.convert('RGBA')

#生成缩略图,减少计算量,减小cpu压力
image.thumbnail((200,200))

max_score=None
dominant_color=None

forcount,(r,g,b,a)inimage.getcolors(image.size[0]*image.size[1]):
#跳过纯黑色
ifa==0:
continue

saturation=colorsys.rgb_to_hsv(r/255.0,g/255.0,b/255.0)[1]

y=min(abs(r*2104+g*4130+b*802+4096+131072)>>13,235)

y=(y-16.0)/(235-16)

#忽略高亮色
ify>0.9:
continue

#Calculatethescore,.
#Add0.1tothesaturationsowedon'tcompletelyignoregrayscale
#,butstillgivethemalow
#weight.
score=(saturation+0.1)*count

ifscore>max_score:
max_score=score
dominant_color=(r,g,b)

returndominant_color

if__name__=="__main__":
fromPILimportImage
importos

path=r'.\pics\'
fp=open('file_color.txt','w')
forfilenameinos.listdir(path):
printpath+filename
try:
color=get_dominant_color(Image.open(path+filename))
fp.write('Thecolorof'+filename+'is'+str(color)+' ')
except:
print"Thisfileformatisnotsupport"
fp.close()


pics文件夹和python程序在一个目录下,产生的文件名file_color.txt也在这个目录下。

看看能否帮到你

热点内容
手机java模拟器 发布:2025-09-18 07:13:29 浏览:413
linux线程的栈大小 发布:2025-09-18 07:09:42 浏览:630
废旧电脑做linux服务器 发布:2025-09-18 07:06:50 浏览:261
终端配置怎么写 发布:2025-09-18 06:44:42 浏览:800
ftp手机登陆 发布:2025-09-18 06:43:04 浏览:763
emc存储800电话 发布:2025-09-18 06:32:49 浏览:960
c语言编程与设计 发布:2025-09-18 06:09:15 浏览:721
2016年预算法 发布:2025-09-18 06:07:05 浏览:622
什么是广告脚本设计 发布:2025-09-18 05:52:09 浏览:657
移动版我的世界服务器 发布:2025-09-18 05:38:49 浏览:965