【教学类-64-02】20240610色块眼力挑战(二)-2-25宫格色差10-100(10倍)(星火讯飞)

背景需求

以下的色块眼里挑战需要人工筛选图片,非常繁琐。

【教学类-64-01】20240607色块眼力挑战(一)-0-255随机底色-CSDN博客文章浏览阅读446次,点赞12次,收藏5次。【教学类-64-01】20240607色块眼力挑战(一)-0-255随机底色https://blog.csdn.net/reasonsummer/article/details/139522756?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22139522756%22%2C%22source%22%3A%22reasonsummer%22%7D

目前没有AI对话大师,无法用它写程序了。

因此在网络上搜索相关的代码,找到moyuweiqing的【Python小游戏】使用tkinter制作不同的找不同色块小游戏。

【Python小游戏】使用tkinter制作不同的找不同色块小游戏-CSDN博客文章浏览阅读377次。测一测你的色差情况_找不同色块https://blog.csdn.net/moyuweiqing/article/details/134263628

原作者代码

'''
作者:moyuweiqing
https://blog.csdn.net/moyuweiqing/article/details/134263628
'''

from tkinter import *
from tkinter import messagebox
import numpy as np
import random
 
start_grid_num = 2              # 开始的每行格子数
grid_num = start_grid_num       # 每次调用时候的每行格子数
size = 800                      # 画布的大小
margin = 2                      # 格子边缘大小
max_grid_num = 25               # 最大的每行格子数
 
start_color_gap = 40            # 开始的色块差
min_color_gap = 5               # 最小色块差
color_gap = start_color_gap     # 每次调用时候的色块差
color_list = []                 # 颜色列表
each_size = 0                   # 每块格子的大小
A = np.full((grid_num, grid_num), 0)    # 矩阵
 
score = 0                       # 计算分数
 
def get_random_position(length):
    random_x = random.randint(0, length - 1)
    random_y = random.randint(0, length - 1)
    return random_x, random_y
 
def change_color_from_rgb(rgb):
    return "#%02x%02x%02x" % (rgb[0], rgb[1], rgb[2])
 
def color_change():
    global color_list, color_gap
    color_list = []
    rgb_set1 = [random.randint(0, 255 - color_gap), random.randint(0, 255 - color_gap), random.randint(0, 255 - color_gap)]
    rgb_set2 = list((i + color_gap for i in rgb_set1))
    color_list.append(change_color_from_rgb(rgb_set1))
    color_list.append(change_color_from_rgb(rgb_set2))
 
    if color_gap > min_color_gap:
        color_gap -= 1
 
def draw():
    global grid_num, each_size, A
    A = np.full((grid_num, grid_num), 0)
    each_size = size // grid_num
    s_x, s_y = get_random_position(grid_num)
    A[s_x][s_y] = -1
 
    canvas.delete('all')
    color_change()
 
    # 画方块
    for i in range(0, grid_num):
        for j in range(0, grid_num):
            if A[i][j] == 0:
                canvas.create_rectangle(i * each_size + margin, j * each_size + margin, (i + 1) * each_size - margin,
                                        (j + 1) * each_size - margin,
                                        fill=color_list[0])
            elif A[i][j] == -1:
                canvas.create_rectangle(i * each_size + margin, j * each_size + margin, (i + 1) * each_size - margin,
                                        (j + 1) * each_size - margin,
                                        fill=color_list[1])
    if grid_num < max_grid_num:
        grid_num += 1
 
def if_right(x, y):
    global score
    xx = x // each_size
    yy = y // each_size
    if A[xx][yy] == -1:
        score += 1
        return True
    else:
        return False
 
def click(event):
    if if_right(event.x, event.y):
        draw()
    else:
        messagebox.showinfo('游戏结束!', '您的分数是:' + str(score))
        tk.destroy()
 
if __name__ == '__main__':
    tk = Tk()
    tk.title('找不同色块')
 
    canvas = Canvas(tk, width=size, height=size, background='lightcyan')
    canvas.pack()
    draw()
 
    canvas.bind("<Button -1>", click)
 
    tk.mainloop()

存在问题:

我的电脑上始终无法安装tkinter,所以我不想做成TK界面小程序,只想要图片就行。

解决方式1——使用文心一言修改代码

但是源代码字母超过2000字符,没有办法完整输入代码,并写入需求

解决方式2——使用讯飞星火

讯飞星火是免费的,可以输入超过2000字的代码,并输入需求

成果展示:

通过对moyuweiqing的【Python小游戏】使用tkinter制作不同的找不同色块小游戏。代码的修改,实现了快速获得“2-25宫格”“色差从10-100”“题卡和答案”“导入PPT”四种需求

'''
目的:不同的找不同色块小游戏(从2宫格-25宫格,色差从10,20^100)有提卡和答案,从难度1-10(难度1就是色差100,难度10是色彩10)
图片导入PPT
原作者:moyuweiqing
https://blog.csdn.net/moyuweiqing/article/details/134263628
改编:星火讯飞,阿夏
时间:2024年6月9日
'''

print('------1、图片和答案----------')
from PIL import Image, ImageDraw  # 导入PIL库中的Image和ImageDraw模块
import numpy as np  # 导入numpy库并简写为np
import random ,os # 导入random库

path = r'C:\Users\jg2yXRZ\OneDrive\桌面\辨认色彩图'
new_path=path+r'\01样式'  # 图片保存路径
os.makedirs(new_path,exist_ok=True)

z=1                             # 份数
start_grid_num = 2              # 开始的每行格子数
grid_num = start_grid_num       # 每次调用时候的每行格子数
size = 800                      # 画布的大小
margin = 2                      # 格子边缘大小
max_grid_num = 25             # 最大的每行格子数

# 色块颜色差
color_start=10                  # 起始的色块值(最小)
color_end=100              # 结束的色块值(最大)
color_gap=10                    # 最大最小色块值的间隔数量 如10个数字一次


# 开始的色块差,10的色块与其他底色相同,看不清清除,,100数字越大,对比越清晰,看的清除
start_color_gap = list(range(color_start,color_end+color_start, color_gap))    
# start_color_gap = list(range(100, 0, -10))      # 为了从简单(100)到难(10),数字翻过来

# 难度,从色块颜色差里提取
nd=list(range(int(color_end/color_gap),int(color_start/color_gap)-1,-int(color_gap/color_gap)))
# (10,0,-1)

# start_color_gap = list(range(100, 0, -10))      # 为了从简单(100)到难(10),数字翻过来
print(start_color_gap)
min_color_gap = 5               # 最小色块差
color_list = []                 # 颜色列表
each_size = 0                   # 每块格子的大小
A = np.full((grid_num, grid_num), 0)    # 矩阵
max_color_gap = 25  

def get_random_position(length):
    random_x = random.randint(0, length - 1)  # 随机生成x坐标
    random_y = random.randint(0, length - 1)  # 随机生成y坐标
    return random_x, random_y

def change_color_from_rgb(rgb):
    return "#%02x%02x%02x" % (rgb[0], rgb[1], rgb[2])  # 将RGB颜色转换为十六进制颜色

def color_change():
    global color_list, color_gap
    color_list = []  # 清空颜色列表
    rgb_set1 = [random.randint(0, 255 - color_gap), random.randint(0, 255 - color_gap), random.randint(0, 255 - color_gap)]  # 生成第一个颜色的RGB值
    rgb_set2 = list((i + color_gap for i in rgb_set1))  # 生成第二个颜色的RGB值
    color_list.append(change_color_from_rgb(rgb_set1))  # 将第一个颜色添加到颜色列表中
    color_list.append(change_color_from_rgb(rgb_set2))  # 将第二个颜色添加到颜色列表中

    if color_gap > min_color_gap:
        color_gap -= 1  # 如果当前颜色间隔大于最小颜色间隔,则减小颜色间隔

if __name__ == '__main__': 
    for aa in range(z):    # 每个宫格2张
        for zz in range(len(start_color_gap)): 
            start_grid_num = 2              # 开始的每行格子数
            grid_num = start_grid_num       # 每次调用时候的每行格子数   
            for yy in range(start_grid_num, max_grid_num + 1): 
                color_gap = start_color_gap[zz]
                print(color_gap)
                A = np.full((grid_num, grid_num), 0)  # 重置二维数组
                each_size = size // grid_num  # 计算每个网格的尺寸
                s_x, s_y = get_random_position(grid_num)  # 获取随机位置
                A[s_x][s_y] = -1  # 将随机位置的值设为-1

                img1 = Image.new('RGB', (size, size), 'lightcyan')  # 创建一个新的图片对象
                img2 = Image.new('RGB', (size, size), 'lightcyan')  # 创建一个新的图片对象
                draw1 = ImageDraw.Draw(img1)  # 创建一个绘图对象
                draw2 = ImageDraw.Draw(img2)  # 创建一个绘图对象
                color_change()  # 改变颜色

                for i in range(0, grid_num):
                    for j in range(0, grid_num):
                        if A[i][j] == 0:
                            draw1.rectangle([i * each_size + margin, j * each_size + margin, (i + 1) * each_size - margin, (j + 1) * each_size - margin], fill=color_list[0])  # 绘制矩形并填充颜色
                            draw2.rectangle([i * each_size + margin, j * each_size + margin, (i + 1) * each_size - margin, (j + 1) * each_size - margin], fill=color_list[0])  # 绘制矩形并填充颜色
                        elif A[i][j] == -1:
                            draw1.rectangle([i * each_size + margin, j * each_size + margin, (i + 1) * each_size - margin, (j + 1) * each_size - margin], fill=color_list[1])  # 绘制矩形并填充颜色
                            draw2.rectangle([i * each_size + margin, j * each_size + margin, (i + 1) * each_size - margin, (j + 1) * each_size - margin], fill=color_list[1], outline='white', width=10)  # 绘制矩形并填充颜色,添加黑色边框

                if grid_num <= max_grid_num:
                    grid_num += 1  # 如果当前网格数量小于最大网格数量,则增加网格数量
                img1.save(new_path+fr'\难度{nd[zz]:02d}色彩间距{start_color_gap[zz]:03d}色块差{min_color_gap:03d}格子数{grid_num-1:02d}_01试题.png')  # 保存图片
                img2.save(new_path+fr'\难度{nd[zz]:02d}色彩间距{start_color_gap[zz]:03d}色块差{min_color_gap:03d}格子数{grid_num-1:02d}_02答案.png')  # 保存图片


print('------2、导入PPT----------')

import os
from pptx import Presentation
from pptx.util import Inches

# 创建一个新的PPT文件
ppt = Presentation()

# 设置PPT页面大小为800x800
ppt.slide_width = Inches(8)
ppt.slide_height = Inches(8)

# 获取123文件夹中的所有图片文件
image_folder = new_path
image_files = [f for f in os.listdir(image_folder) if f.endswith(('.png', '.jpg', '.jpeg', '.gif'))]

# 将图片批量导入到PPT中
for image_file in image_files:
    slide = ppt.slides.add_slide(ppt.slide_layouts[6])  # 添加一个空白幻灯片
    img_path = os.path.join(image_folder, image_file)
    left, top, width, height = Inches(0), Inches(0), Inches(8), Inches(8)
    slide.shapes.add_picture(img_path, left, top, width, height)

# 保存PPT文件
ppt.save(path+fr'\01色块小游戏(每种{z}张{start_grid_num}-{max_grid_num}).pptx')

import shutil
shutil.rmtree(new_path)

结果展示

以下是难度1,最简单的,色差100,所以看起来对比明显,最小色差5,从2宫格-25宫格,每个宫格有试题和答案两张

以下是难度10,最难的,色差10,几乎看不出色彩差异,最小色差5,从2宫格-25宫格,每个宫格有试题和答案两张

把所有2宫格图像提取出来,可以看,色差越大(100),辨认难度越小,所以放在难度是1,色差越小(10)辨认难度越高(几乎与周边颜色相同),所以难度10。

图片放大看,

这样生成速度很快。一共480图,实际240图

保存为PPT。

视频展示

202406106色块小游戏

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/714066.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C语言——自定义类型:结构体

前言 本篇博客位大家介绍C语言中一块儿重要的内容&#xff0c;那就是结构体&#xff0c;关于结构体的内容&#xff0c;大家需要深入掌握&#xff0c;在后面的学习中依然会用到&#xff0c;如果你对本文感兴趣&#xff0c;麻烦点进来的老铁一键三连。多多支持&#xff0c;下面我…

食家巷助力“甘肃乡村振兴,百强主播·打call 甘味”活动

2024年&#xff0c;甘肃省“商务乡村振兴”促消费暨“百强主播打call 甘味”活动在天水市龙城广场盛大启动。 活动现场&#xff0c;来自甘肃省 14 个市州的农特产品展台琳琅满目&#xff0c;让人目不暇接。此次活动中&#xff0c;各企业带来了多款深受消费者喜爱的产品&a…

【C++提高编程-06】----C++之STL-函数对象、谓词、仿函数

&#x1f3a9; 欢迎来到技术探索的奇幻世界&#x1f468;‍&#x1f4bb; &#x1f4dc; 个人主页&#xff1a;一伦明悦-CSDN博客 ✍&#x1f3fb; 作者简介&#xff1a; C软件开发、Python机器学习爱好者 &#x1f5e3;️ 互动与支持&#xff1a;&#x1f4ac;评论 &…

这 10 种架构师,不合格!

大家好&#xff0c;我是君哥。 架构师这个岗位是好多程序员努力的方向&#xff0c;尤其是刚毕业的时候&#xff0c;对架构师有一种崇拜感。毕竟从初级到架构要经历好几次级别飞跃。 工作时间久了&#xff0c;发现架构师这个岗位&#xff0c;其实定义非常广泛&#xff0c;根据工…

linux 部署瑞数6实战(维普,药监局)sign第二部分

声明 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01;wx …

如何通过在线封装APP快速上线?小猪APP分发帮你解决难题

你是否曾经为了上线一款APP而头疼不已&#xff1f;开发完成后&#xff0c;封装、测试、分发&#xff0c;这些繁琐的步骤让人望而却步。别担心&#xff0c;小猪APP分发来了&#xff01;这篇文章将带你了解如何通过在线封装APP快速上线&#xff0c;并且告诉你为什么选择小猪APP分…

[Linux] TCP协议介绍(3): TCP协议的“四次挥手“过程、状态分析...

TCP协议是面向连接的 上一篇文章简单分析了TCP通信非常重要的建立连接的"三次握手"的过程 本篇文章来分析TCP通信中同样非常重要的断开连接的"四次挥手"的过程 TCP的"四次挥手" TCP协议建立连接 需要"三次握手". "三次挥手&q…

Postman下发流表至Opendaylight

目录 任务目的 任务内容 实验原理 实验环境 实验过程 1、打开ODL控制器 2、网页端打开ODL控制页面 3、创建拓扑 4、Postman中查看交换机的信息 5、L2层流表下发 6、L3层流表下发 7、L4层流表下发 任务目的 1、掌握OpenFlow流表相关知识&#xff0c;理解SDN网络中L…

飞书API 2-1:如何通过 API 创建文件夹?

本文探讨如何通过飞书的 API 来创建文件夹。通过 API 创建的文件夹&#xff0c;一般是放在共享空间&#xff0c;如果要放在个人空间&#xff0c;建议手动创建。 查看 API 文档 API 路径&#xff0c;可在飞书开放平台的服务端 API&#xff0c;依次查找云文档>云空间>文件…

javaWeb项目-springboot+vue人事管理系统功能介绍

本项目源码&#xff1a;java-springbootvue人事管理系统源码说明文档资料资源-CSDN文库 项目关键技术 开发工具&#xff1a;IDEA 、Eclipse 编程语言: Java 数据库: MySQL5.7 框架&#xff1a;ssm、Springboot 前端&#xff1a;Vue、ElementUI 关键技术&#xff1a;springboot…

高级人工智能复习 题目整理 中科大

题目整理 填空 1.准确性&#xff0c;复杂性&#xff0c;验证集 2. 3 2 n 3^{2^n} 32n 3 C 2 n m 3^{C^m_{2n}} 3C2nm​ 3 m 3^m 3m n 1 n1 n1 3. 状态 从状态s采取行动a后继续采用策略 π \pi π的收益 环境 4. 语法 语义 推理规则 5. 参与者&#xff0c;策略集&#xff…

算法排序之冒泡排序及优化

public class Bubbling {public static void main(String[] args) {// 定义需要排序的数组int[] arr {0,1,21,2,31,12,5,8};// 冒泡排序方法bubbleSort(arr);bubbleOptSort(arr);}/*** 冒泡排序* param arr 数组*/public static void bubbleSort(int[] arr){// i0&#xff0c;…

【C语言】解决C语言报错:Format String Vulnerability

文章目录 简介什么是Format String VulnerabilityFormat String Vulnerability的常见原因如何检测和调试Format String Vulnerability解决Format String Vulnerability的最佳实践详细实例解析示例1&#xff1a;直接使用不受信任的输入作为格式化字符串示例2&#xff1a;未验证格…

英伟达开源最强通用模型Nemotron-4 340B:开启AI合成数据新纪元

【震撼发布】 英伟达最新力作——Nemotron-4 340B,一个拥有3400亿参数的超级通用模型,震撼登场!这不仅是技术的一大飞跃,更是AI领域的一次革命性突破! 【性能卓越】 Nemotron-4 340B以其卓越的性能超越了Llama-3,专为合成数据而生。它将为医疗健康、金融、制造、零售等行…

基于WPF技术的换热站智能监控系统09--封装水泵对象

1、添加用户控件 2、编写水泵UI 控件中用到了Viewbox控件&#xff0c;Viewbox控件是WPF中一个简单的缩放工具&#xff0c;它可以帮助你放大或缩小单个元素&#xff0c;同时保持其宽高比。通过样式和属性设置&#xff0c;你可以创建出既美观又功能丰富的用户界面。在实际开发中…

RabbitMQ揭秘:轻量级消息队列的优缺点全解析

我是小米,一个喜欢分享技术的29岁程序员。如果你喜欢我的文章,欢迎关注我的微信公众号“软件求生”,获取更多技术干货! 亲爱的读者朋友们,大家好!我是小米,一个热爱技术、喜欢分享的大哥哥。今天我们来聊聊一个在消息队列领域非常重要的工具——RabbitMQ。作为一个在通信…

EasyExcel文件导出,出现有文件但没有数据的问题

一开始由于JDK版本过高&#xff0c;我用的17&#xff0c;一直excel没有数据&#xff0c;表头也没有&#xff0c;后来摸索了好久&#xff0c;找了资料也没有&#xff0c;后来改了代码后报了一个错误&#xff08;com.alibaba.excel.exception.ExcelGenerateException: java.lang.…

如何让视频有高级感 高级感视频制作方法 高级感视频怎么剪 会声会影视频剪辑制作教程 会声会影中文免费下载

高质量视频通常具有清晰的画面、优质的音频和令人印象深刻的视觉效果。这篇文章来了解如何让视频有高级感&#xff0c;高级感视频制作方法。 一、如何让视频有高级感 要让视频有高级感&#xff0c;要注意以下几个要点&#xff1a; 1、剧本和故事性&#xff1a;一个好的剧本和…

Vue主要使用-03

组件通讯 组件通讯也是我们需要了解的,在我们的实际开发中,我们使用的非常多,比如父组件内的数据传入到子组件,子组件的数据传入到父组件,什么是父组件什么是子组件&#xff1f;父组件内包含着我们的子组件,我们的父组件可以有多个子组件,父组件就是我们使用子组件拼接的。 …

001 Spring介绍

文章目录 特点1.方便解耦&#xff0c;简化开发2.AOP编程的支持3.声明式事务的支持4.方便程序的测试5.方便集成各种优秀框架6.降低Java EE API的使用难度7.Java源码是经典学习范例 好处什么是耦合和内聚耦合性&#xff0c;也叫耦合度&#xff0c;是对模块间关联程度的度量内聚标…