【教学类-56-01】数感训练——数字01(同样的数字涂色)

背景需求:

数感训练《1-10数字🔢练习》 - 小红书#儿童专注力训练 #数感启蒙 #数学启蒙icon-default.png?t=N7T8https://www.xiaohongshu.com/discovery/item/66186e2a000000001a0146c6?app_platform=android&ignoreEngage=true&app_version=8.35.0&share_from_user_hidden=true&type=normal&author_share=1&xhsshare=WeixinSession&shareRedId=ODszMTs4Nk82NzUyOTgwNjg3OTlHS0xC&apptime=1715501410

小红书上的“数感训练”——在一堆数字圆圈里,画出和坐上叫一样的数字(涂色)

素材准备

代码展示

'''
数感训练-0-10数字
AI对话大师,阿夏
2024年5月18日

'''

import random
import math
from PIL import Image, ImageDraw, ImageFont

path = r'C:\Users\jg2yXRZ\OneDrive\桌面\数字数感训练\jpg'
canvas_width, canvas_height = 3000, 4000  # 调整画布的宽度和高度

numbers = [i for i in range(0,10)]
print(numbers)

n=0
for i in numbers:
    # 创建白色画布
    canvas_color = (255, 255, 255)
    canvas = Image.new('RGB', (canvas_width, canvas_height), canvas_color)
    draw = ImageDraw.Draw(canvas)

    # 字体设置
    font_path = r"C:\Windows\Fonts\simhei.ttf"  # 黑体字体路径,请根据实际情况修改
    font_size = 500
    font = ImageFont.truetype(font_path, font_size)

    # 在左上角绘制阴影效果
    shadow_color = (100, 100, 100)
    shadow_offset = (8, 8)
    draw.text((100 + shadow_offset[0], 100 + shadow_offset[1]), fr'{i}', font=font, fill=shadow_color)

    # 在左上角绘制数字1
    text_color = (0, 0, 0)
    draw.text((100, 100), fr'{i}', font=font, fill=text_color)

    # 生成10磅黑线白色圆圈
    circle_radius = 100
    circle_border_color = (0, 0, 0)
    circle_fill_color = (255, 255, 255)
    border_width = 10
    circle_distance = 60 + circle_radius * 2  # 圆圈之间的距离
    # 圆形于边框的距离
    bj=30

    # 存储圆圈的位置信息,用于检查是否相交
    circle_positions = []

    # 阿拉伯数字字体设置
    number_font_size = 150
    number_font = ImageFont.truetype(font_path, number_font_size)

    # 计算可以生成圆圈的区域范围circle_distance 加了一个园的距离,离开边框就大了
    # min_x = circle_radius + border_width + circle_distance 
    # max_x = canvas_width - circle_radius - border_width - circle_distance
    # min_y = circle_radius + border_width + circle_distance 
    # max_y = canvas_height - circle_radius - border_width - circle_distance 
    min_x = circle_radius + border_width +  bj
    max_x = canvas_width - circle_radius - border_width - bj
    min_y = circle_radius + border_width +  bj
    max_y = canvas_height - circle_radius - border_width - bj

    for _ in range(500):
        # 生成圆心位置
        x = random.randint(min_x, max_x)
        y = random.randint(min_y, max_y)

        # 排除左上角区域
        if x <= 800 and y <= 800:
            continue

        # 检查与已有圆圈是否相交
        is_intersect = False
        for position in circle_positions:
            distance = math.sqrt((x - position[0]) ** 2 + (y - position[1]) ** 2)
            if distance < circle_distance:
                is_intersect = True
                break

        if not is_intersect:
            # 绘制外圆,边线粗细为10磅
            outer_circle_radius = circle_radius + border_width
            outer_circle_bbox = (
                x - outer_circle_radius, y - outer_circle_radius, x + outer_circle_radius, y + outer_circle_radius)
            draw.ellipse(outer_circle_bbox, fill=circle_border_color)

            # 绘制内圆,填充为白色
            inner_circle_radius = circle_radius
            inner_circle_bbox = (
                x - inner_circle_radius, y - inner_circle_radius, x + inner_circle_radius, y + inner_circle_radius)
            draw.ellipse(inner_circle_bbox, fill=circle_fill_color)

            # 在圆圈内绘制随机生成的阿拉伯数字
            number = random.choice(numbers)
            number_width, number_height = draw.textsize(str(number), font=number_font)
            number_x = x - number_width // 2
            number_y = y - number_height // 2
            draw.text((number_x, number_y), str(number), font=number_font, fill=text_color)

            # 将圆圈位置添加至列表
            circle_positions.append((x, y))

    # 保存为1.png
    canvas.save(path + fr'\{n:02d}.png')
    n+=1

修改数字,还可以变成跟更大的数字

  • 16
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要截取 YOLOv7-segmentation 涂色区域,你可以按照以下步骤进行操作: 1. 首先,使用 YOLOv7-segmentation 模型对图像进行分割,得到每个像素的别和对应的颜色。 2. 根据任务需求,确定你想要截取的涂色区域的别和对应的颜色。 3. 遍历图像的每个像素,将属于目标别的像素标记出来。 4. 根据标记的像素,计算包围涂色区域的最小矩形框。 5. 使用图像处理库(如 OpenCV)根据矩形框的坐标截取涂色区域。 下面是一个简单的示例代码,演示如何截取 YOLOv7-segmentation 涂色区域: ```python import cv2 import numpy as np # 加载分割模型和图像 model = load_yolov7_segmentation_model() image = load_image() # 进行图像分割,得到每个像素的别和颜色 segmentation_map = model.segment(image) # 定义目标别和颜色 target_class = "person" target_color = [0, 255, 0] # 绿色 # 遍历图像的每个像素,标记目标别的像素 target_pixels = np.where(segmentation_map == target_color) # 计算包围涂色区域的最小矩形框 x, y, w, h = cv2.boundingRect(target_pixels) # 截取涂色区域 cropped_region = image[y:y+h, x:x+w] # 显示截取的涂色区域 cv2.imshow("Cropped Region", cropped_region) cv2.waitKey(0) cv2.destroyAllWindows() ``` 请注意,以上代码仅为示例,你需要根据实际情况进行适当的修改和调整。此外,你还需要替换示例代码中的 `load_yolov7_segmentation_model()` 和 `load_image()` 函数,以便正确加载和处理模型和图像。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿夏reasonsummer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值