当前位置: 首页 > news >正文

Python 提取图片主色调

Python 提取图片主色调

  • 效果
  • 代码编写

效果

有个要提取图片主色调的需求,记录一下。
获取图片中的主色调

代码编写

import numpy as np
import cv2
from sklearn.cluster import KMeans
from skimage.color import rgb2lab, deltaE_cie76
from collections import Counter# 创建默认变量# 这是用于确定背景的阈值
remove_background_threshold = 235
# 这是用于确定要提取的颜色数量的参数
extract_colors_num_colors = 8
# 这是用于确定两种颜色是否相似的阈值
is_similar_color_threshold = 30def remove_background(image, threshold=remove_background_threshold):# Convert image to grayscale# 将图像转换为灰度图gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)# Create a binary mask of the background# 创建一个背景的二值掩码_, mask = cv2.threshold(gray, threshold, 255, cv2.THRESH_BINARY_INV)# Apply the mask to the original image# 将掩码应用到原始图像上result = cv2.bitwise_and(image, image, mask=mask)return resultdef get_color_name(lab):colors = {"red": [53.23, 80.11, 67.22],"green": [87.74, -86.18, 83.18],"blue": [32.30, 79.19, -107.86],"yellow": [97.14, -21.55, 94.48],"cyan": [91.11, -48.09, -14.13],"magenta": [60.32, 98.24, -60.83],"black": [0, 0, 0],"white": [100, 0.00, -0.01],"gray": [53.59, 0, 0],"orange": [67.79, 43.30, 74.93],"purple": [29.78, 58.94, -36.50],"brown": [38.91, 19.36, 22.29],"pink": [88.22, 17.75, 3.18],"dark red": [39.35, 62.75, 49.91],"light blue": [79.19, -11.03, -26.23],"dark green": [35.49, -46.47, 35.45],"light green": [88.72, -42.89, 57.40],"navy": [16.73, 37.09, -65.49],"burgundy": [28.71, 49.35, 26.27],"beige": [89.02, -1.39, 11.09],"olive": [51.87, -12.93, 56.67],"teal": [49.31, -28.83, -8.48],"maroon": [25.64, 45.52, 20.77],"forest green": [36.23, -37.96, 30.20],}min_dist = float('inf')closest_color = Nonefor color_name, color_lab in colors.items():dist = np.sqrt(sum((lab - color_lab) ** 2))if dist < min_dist:min_dist = distclosest_color = color_namereturn closest_colordef is_similar_color(color1, color2, threshold=is_similar_color_threshold):lab1 = rgb2lab([[color1]])[0][0]lab2 = rgb2lab([[color2]])[0][0]diff = deltaE_cie76(lab1, lab2)return diff < thresholddef extract_colors(image_path, num_colors=extract_colors_num_colors):# Read image# 读取图像image = cv2.imread(image_path)image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)# Remove background# 去除背景image_no_bg = remove_background(image)# Reshape image# 重塑图像pixels = image_no_bg.reshape(-1, 3)# Remove black pixels (background)# 删除黑色像素(背景)pixels = pixels[~np.all(pixels == [0, 0, 0], axis=1)]if len(pixels) == 0:return []  # Return empty list if all pixels were removed   返回空列表,如果所有像素都被删除# Perform k-means clustering# 执行k-means聚类kmeans = KMeans(n_clusters=num_colors, random_state=42, n_init=10)kmeans.fit(pixels)# Get the colors# 获取颜色colors = kmeans.cluster_centers_# Convert colors to LAB space# 将颜色转换为LAB空间colors_lab = rgb2lab(colors.reshape(1, -1, 3)).reshape(-1, 3)# Get color names# 获取颜色名称color_names = [get_color_name(color) for color in colors_lab]# Count pixels for each cluster# 计算每个聚类的像素数pixel_counts = Counter(kmeans.labels_)# Sort colors by frequency# 按频率对颜色进行排序sorted_colors = sorted(zip(color_names, colors, pixel_counts.values()), key=lambda x: x[2], reverse=True)# Remove similar colors# 删除相似颜色unique_colors = []for color_name, color_rgb, count in sorted_colors:if color_name not in [uc[0] for uc in unique_colors] and \not any(is_similar_color(color_rgb, existing_color) for _, existing_color, _ in unique_colors):unique_colors.append((color_name, color_rgb, count))if len(unique_colors) == 3:breakreturn [color_name for color_name, _, _ in unique_colors]# Example usage
image_path = r'D:\Project\Python_Project\yitiaolong\expimage_1.jpg'
main_colors = extract_colors(image_path)
print("Main colors:", main_colors)

相关文章:

  • Canvas 指纹:它是什么以及如何绕过它
  • 聊聊etsy平台,一个年入百万的项目
  • 在编译 PHP 8.3.8 时遇到 configure: error: Package requirements (libxml-2.0 >= 2.9.0)
  • Linux-笔记 全志T113移植正点4.3寸RGB屏幕笔记
  • Spring之事务失效的场景
  • 【推荐】Prometheus+Grafana企业级监控预警实战
  • uniapp微信小程序使用xr加载模型
  • 代谢组数据分析十一:典型相关分析
  • golang使用RSA加密和解密
  • Nosql期末复习
  • 机器人----四元素
  • Cocos制作抖音小游戏接入侧边栏复访接口实例
  • 6.29学习笔记
  • 【RabbitMQ实战】Springboot 整合RabbitMQ组件,多种编码示例,带你实践 看完这一篇就够了
  • ONLYOFFICE 桌面编辑器 8.1全新发布,更强大的编辑工具
  • 10个确保微服务与容器安全的最佳实践
  • C++类的相互关联
  • create-react-app做的留言板
  • Cumulo 的 ClojureScript 模块已经成型
  • GitUp, 你不可错过的秀外慧中的git工具
  • JavaSE小实践1:Java爬取斗图网站的所有表情包
  • Node + FFmpeg 实现Canvas动画导出视频
  • Web设计流程优化:网页效果图设计新思路
  • 翻译:Hystrix - How To Use
  • 区块链将重新定义世界
  • 温故知新之javascript面向对象
  • 写给高年级小学生看的《Bash 指南》
  • 译米田引理
  • 云栖大讲堂Java基础入门(三)- 阿里巴巴Java开发手册介绍
  • #DBA杂记1
  • (el-Transfer)操作(不使用 ts):Element-plus 中 Select 组件动态设置 options 值需求的解决过程
  • (java)关于Thread的挂起和恢复
  • (二)PySpark3:SparkSQL编程
  • (非本人原创)史记·柴静列传(r4笔记第65天)
  • (九)信息融合方式简介
  • (七)c52学习之旅-中断
  • (全部习题答案)研究生英语读写教程基础级教师用书PDF|| 研究生英语读写教程提高级教师用书PDF
  • (转)Android学习笔记 --- android任务栈和启动模式
  • (转)关于如何学好游戏3D引擎编程的一些经验
  • (转载)OpenStack Hacker养成指南
  • .form文件_SSM框架文件上传篇
  • .Net CF下精确的计时器
  • .net core 6 集成和使用 mongodb
  • .NET Core6.0 MVC+layui+SqlSugar 简单增删改查
  • .NET开发人员必知的八个网站
  • .NET设计模式(7):创建型模式专题总结(Creational Pattern)
  • @angular/cli项目构建--Dynamic.Form
  • @DependsOn:解析 Spring 中的依赖关系之艺术
  • @GetMapping和@RequestMapping的区别
  • [ C++ ] STL priority_queue(优先级队列)使用及其底层模拟实现,容器适配器,deque(双端队列)原理了解
  • [ 第一章] JavaScript 简史
  • [120_移动开发Android]008_android开发之Pull操作xml文件
  • [8-23]知识梳理:文件系统、Bash基础特性、目录管理、文件管理、文本查看编辑处理...
  • [BZOJ2208][Jsoi2010]连通数
  • [C#C++]类CLASS