pygame光栅化三角形 用像素填充三角形

news2024/12/25 23:42:10

参考文章
DirectX C++ 3D编程基础 5 [三角形光栅化] 自制中字

这次用像素填充三角形,是为了下次用图片做纹理填充三角形做准备。
前面的文章说了根据直线方程求出已知两点间任意一点的坐标,现在来试试用像素填充三角形。
首先画一个三角形
在这里插入图片描述

pygame.draw.polygon(screen, color, ((ax,ay), (bx, by), (cx, cy)))#左,中,右
                                        #(70, 580), (160, 300), (200, 580)

abc三点坐标为a(70,580) b(160,300) c(200,500)
首先计算点a至点b这条线的斜率
公式为zk=(ay-by)/(ax-bx)#左边斜率
计算求得k=-(280/90)
接下来求截距

jiejuz=(bx*zk)-by#截距

公式y=kx+b, 将点b(160,300)带入公式(带入哪个点都行)
b=(71800/90)
这里做个判断,因为计算b的时候公式为-b=kx-y
要将结果正负转换(这个后续可能还得改)

jz=0
    if jiejuz<0:
        jz=abs(jiejuz)
    else:
        jz=-abs(jiejuz)

现在做个测试,看看对不对
x取值在70-200,y取值在300-580
y取400,看看x在不在这条线上
因为要求x,所以公示改变为-kx=b-y,变化下-x=(b-y)/k
x=127.85714285714288
下图橙色线
在这里插入图片描述
这是三角形左边线的斜率,我们同理求出右边的斜率
现在就可以根据y求出两边直线sx,ex的坐标
在这里插入图片描述

zk=(ay-by)/(ax-bx)#左边斜率
    yk=(by-cy)/(bx-cx)
    #y=kx+b -b=kx-y 但是没法用-b当变量,下面就-abs手动转负数
    jiejuz=(bx*zk)-by#截距
    jz=0
    if jiejuz<0:
        jz=abs(jiejuz)
    else:
        jz=-abs(jiejuz)
    #print(jiejuz,jz)
    '''yz=zk*(70+0.5)+jz
    #y1 = zk * 90 + jieju
    #print(int(46600/90),int(y1), int(yz))
    pygame.Surface.set_at(screen, (90, int(46600/90)), (255,0,0))
    pygame.Surface.set_at(screen, (int(70+0.5), int(yz)), (255,0, 0))
'''
    # (70, 580), (160, 300), (200, 580)

    
    jiejuy=(bx*yk)-by#截距

    jy = 0
    if jiejuy < 0:
        jy = abs(jiejuy)
    else:
        jy = -abs(jiejuy)

    

   
   
    xz = (jz - 300) /zk
    zuoxianx=abs(xz)
    xy=(jy-300)/yk
    youxianx=abs(xy)
    # y1 = zk * 90 + jieju
    # print(int(46600/90),int(y1), int(yz))
    pygame.Surface.set_at(screen, (int(youxianx), 300), (255, 0, 0))
    pygame.Surface.set_at(screen, (int(zuoxianx), 300), (255, 0, 0))

在这里插入图片描述
眼神好的能看见,这两点都画了一个红色像素,现在将这两点连起来

c=int(youxianx)-int(zuoxianx)
    for i in range(c):
        pygame.Surface.set_at(screen, (70+i, int(580)), (0, 255, 0))

在这里插入图片描述
画出了一条绿色线。现在只需要知道高度,就可以将白色三角形填充起来了。
a(70, 580),b (160, 300), c(200, 580)
高度就是580-300
循环280次,从上面开始,也就是从300开始。每次加1,首个数字gao是0。ex = abs(xy1)+2#加2是为了填补空白这个如果不加2个像素会有空白边

xcishu=ex-sx

计算x循环几次,终点x也就是右边的x-左边x

pygame.Surface.set_at(screen, (int(sx) + i, 300+gao), (255, 0, 0))

sx就是当前高度左边x的坐标,x每次加循环次数(xcishu=ex-sx),y是从300开始,每次加gao,也就是高度循环次数

    for gao in range(280):

        xz1 = (jz - (gao+300)) / zk
        sx = abs(xz1)
        xy1 = (jy - (gao+300)) / yk
        ex = abs(xy1)+2#加2是为了填补空白
        xcishu=ex-sx
        print("gao==",gao,"第一次循环",int(sx),int(ex))
        for i in range(int(xcishu)):
            print("i==",i,"第二次循环",int(sx),int(ex))

            # pygame.Surface.set_at(screen, (i, int(580)), (0, 255, 0))
            pygame.Surface.set_at(screen, (int(sx) + i, 300+gao), (255, 0, 0))

在这里插入图片描述
如果没加2的话是这样的
在这里插入图片描述
下面是完整代码

import pygame
import sys
from pygame import gfxdraw

(width, height) = (600, 600)
pygame.init()
screen = pygame.display.set_mode((width, height))
image = pygame.image.load("1.png").convert_alpha()
masked_result = image.copy()

white_color = (255, 255, 255)
polygon =[(0, 0), (800, 600), (0, 600)]
#(260,0),(200,0),(200,130),(260,130)

#[(0.0, 307.6923076923077), (723.0769230769231, 307.6923076923077), (972.4137931034483, 413.7931034482759), (0.0, 413.7931034482759)]
image = pygame.image.load("1.png")
car = pygame.transform.scale(image, (100, 100))


#screen.fill((0,0,0))
#screen.blit(image, (140,140))
screensurf = pygame.display.get_surface()#获取当前显示的 Surface 对象
color=(255, 255, 255)

img=pygame.image.load("1.png").convert_alpha()
ix=0#纹理坐标
iy=0
px=310#画出来填充像素坐标
py=310

ax=70
ay=580
bx=160
by=300
cx=200
cy=580
#(70, 580), (160, 300), (200, 580)
while True:
    for event in pygame.event.get():
        if event.type == pygame.QUIT:
            sys.exit()
        if event.type == pygame.MOUSEBUTTONDOWN:
            mouse = pygame.mouse.get_pos()
            '''pxarray = pygame.PixelArray(screensurf)
            pixel = pygame.Color(pxarray[mouse[0], mouse[1]])#获取像素
            print (pixel)
            print (screensurf.get_at(mouse))#颜色
            print(mouse[0], mouse[1],mouse)#点击坐标
            print(img.get_at(mouse))#颜色'''
            #pygame.Surface.set_at(screen, (140, 140), (img.get_at(mouse)))
            print(mouse[0], mouse[1], mouse)  # 点击坐标
    #gfxdraw.pixel(screen, 90, 90, color)#画一个像素
    w=img.get_width()
    h=img.get_height()
    #print(w,h)
    for ih in range(h):
        for iw in range(w):
            pygame.Surface.set_at(screen, (px+iw, py+ih), (img.get_at((ix+iw,iy+ih))))
                        #(px+iw, py+ih)是当前绘制x,y像素位置  img.get_at((ix+iw,iy+ih)是获取图片中对应位置的颜色
            #print(px+iw, py+ih)
    pygame.draw.polygon(screen, color, ((ax,ay), (bx, by), (cx, cy)))#左,中,右
                                        #(70, 580), (160, 300), (200, 580)
    zk=(ay-by)/(ax-bx)#左边斜率
    yk=(by-cy)/(bx-cx)
    #y=kx+b -b=kx-y 但是没法用-b当变量,下面就-abs手动转负数
    jiejuz=(bx*zk)-by#截距
    jz=0
    if jiejuz<0:
        jz=abs(jiejuz)
    else:
        jz=-abs(jiejuz)
    #print(jiejuz,jz)
    '''yz=zk*(70+0.5)+jz
    #y1 = zk * 90 + jieju
    #print(int(46600/90),int(y1), int(yz))
    pygame.Surface.set_at(screen, (90, int(46600/90)), (255,0,0))
    pygame.Surface.set_at(screen, (int(70+0.5), int(yz)), (255,0, 0))
'''
    # (70, 580), (160, 300), (200, 580)

    yk = (by - cy) / (bx - cx)
    jiejuy=(bx*yk)-by#截距

    jy = 0
    if jiejuy < 0:
        jy = abs(jiejuy)
    else:
        jy = -abs(jiejuy)

    yy = yk * 200 + jy

    pygame.Surface.set_at(screen, (200, int(yy)), (0, 255, 0))

    yz = zk * (70 + 0.5) + jz
    #y=kx+b   -kx=b-y
    #xz=((5/3)-(8/3))/(1/3)
    xz = (jz - 300) /zk
    zuoxianx=abs(xz)
    xy=(jy-300)/yk
    youxianx=abs(xy)
    # y1 = zk * 90 + jieju
    # print(int(46600/90),int(y1), int(yz))
    pygame.Surface.set_at(screen, (int(youxianx), 300), (255, 0, 0))
    pygame.Surface.set_at(screen, (int(zuoxianx), 300), (255, 0, 0))
    starx=int(zuoxianx)
    endx=int(youxianx)
    print(yk,"截距左", jz, jy, "右扫描线y", yy, "左边扫描线y", yz,"左扫描线x",zuoxianx,"左扫描线x",youxianx)
    dong=0
    stary=300
    endy=580

    for gao in range(280):

        xz1 = (jz - (gao+300)) / zk
        sx = abs(xz1)
        xy1 = (jy - (gao+300)) / yk
        ex = abs(xy1)#加2是为了填补空白
        xcishu=ex-sx
        print("gao==",gao,"第一次循环",int(sx),int(ex))
        for i in range(int(xcishu)):
            print("i==",i,"第二次循环",int(sx),int(ex))

            # pygame.Surface.set_at(screen, (i, int(580)), (0, 255, 0))
            pygame.Surface.set_at(screen, (int(sx) + i, 300+gao), (255, 0, 0))
    pygame.display.update()


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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

whisperX 语音识别本地部署

WhisperX 是一个优秀的开源Python语音识别库。 下面记录Windows10系统下部署Whisper 1、在操作系统中安装 Python环境 2、安装 CUDA环境 3、安装Annaconda或Minconda环境 4、下载安装ffmpeg 下载release-builds包&#xff0c;如下图所示 将下载的包解压到你想要的路径&#xf…

华为OD机试之Boss分销提成计算(boss的收入)(Java源码)

Boss分销提成计算&#xff08;boss的收入&#xff09; 题目描述 一个XX产品行销总公司&#xff0c;只有一个boss&#xff0c;其有若干一级分销&#xff0c;一级分销又有若干二级分销&#xff0c;每个分销只有唯一的上级分销. 规定&#xff0c;每个月&#xff0c;下级分销需要将…

利用OpenCV做个熊猫表情包吧

有的时候很想把一些有意思的图中的人脸做成熊猫表情&#xff0c;但是由于不太会ps&#xff0c;只能无奈放弃&#xff0c;so sad... 正好最近想了解下opencv的使用&#xff0c;那就先试试做个简单的熊猫表情生成器把~~ 思路就是&#xff0c;工具给两个参数&#xff0c;一个是人…

矩阵卷积之边缘计算

目录 note code test note code // 不扩充边缘的矩阵卷积&#xff0c;输出矩阵和输入矩阵一样大 void MyMatConvolute2(Mat& src, Mat& kernel, Mat& res) {if (src.type() ! CV_8UC1) {return;}if ((kernel.type() ! CV_8UC1) || (kernel.rows ! kernel.cols) …

2023年端午节放假通知

过节、业务两不误&#xff0c;服务“不打烊”。欢迎新老客户前来咨询下单&#xff01;感谢各位一直以来的支持和信赖&#xff0c;你们是易天光通信成长道路上不可或缺的力量&#xff0c;提前祝大家在端午节玩得开心&#xff0c;吃得开心&#xff01; 深圳易天光通信有限公司 …

C#打印控件ReportViewer使用总结(三)

ReportViewer控件设计 在工具箱中添加ReportViewer控件&#xff0c;控件名称为reportViewer1。 2.绑定报表和数据集 /// <summary> /// 绑定报表和数据集 /// </summary> private void DataBing() { //绑定报表 this.reportViewer1.LocalReport.ReportPath Syste…

Java官方笔记8泛型

泛型 为什么需要泛型&#xff1f;generics enable types (classes and interfaces) to be parameters when defining classes, interfaces and methods. 说白了就像Python动态语言的变量&#xff0c;是动态的&#xff0c;可以指向任意类型。 泛型有个好处是不需要类型转换&…

有没有不限制群发数量的软件?

父亲节的由来 父亲节&#xff08;Fathers Day&#xff09;&#xff0c;顾名思义是感恩父亲的节日。 世界上第一个父亲节&#xff0c;1910年诞生于美国。 而中国的父亲节起源要追溯到民国时代。民国三十四年的八月八日&#xff08;1945.8.8&#xff09;&#xff0c;上海文人所…

git-在当前分支做变基(rebase current onto selected)

文章目录 git rebase变基git rebase使用场景git rebase还是git merge?在当前分支做变基使用总结 git rebase变基 初学git&#xff0c;在合并分支上必定会常用到 git merge 语法。git除了使用合并(merge)集成2个分支之间的更改&#xff0c;还有另外一种称为rebase的方法。 gi…

R -- corrplot包

文章目录 常用参数简介method测试部分type参数测试diag参数测试order参数测试 常用参数简介 corrplot包常用参数介绍&#xff1a; corr: 必需参数&#xff0c;表示相关性矩阵&#xff0c;可以是数据框或者矩阵。 method: 表示绘制相关性矩阵的方法&#xff0c;有以下几种取值…

H5语义化标签

语义化标签 HTML5引入了一组语义化标签,这些标签旨在更好地描述网页内容的结构和含义。通过使用这些标签,可以提高网页的可读性、可访问性、搜索引擎优化,以及代码的可维护性。以下是对HTML5语义化标签的详细解释: <header>:用于定义页面或区块的页眉部分,通…

centos8 KDC认证

20国赛公开卷KDC做法&#xff08;个人整理&#xff09; 先根据题意&#xff0c;用chrony服务同步时间 Linux-1为KDC服务器&#xff0c;认证Linux-2和Linux-3.三台都先同步时间。 所有的Linux selinux都为enforcing&#xff0c;防火墙都是打开的。此次为临时测试整理&#xff…

Java常见面试题之SSM | Spring Boot(不定时更新)

IOC DI机制 IOC的意思是控制反转,控制的意思啊由Spring 工厂控制对象,反转是从我们主动创建好对象反转为等待Spring 工厂的注入 DI是依赖注入,组件需要的依赖对象由容器注入,主要通过setter 构造器 接口三种注入方式注入. AOP 面向切面编程 AOP思想是做无侵入式的功能增强,即在…

English Learning - L3 作业打卡 Lesson6 Day40 2023.6.13 周二

English Learning - L3 作业打卡 Lesson6 Day40 2023.6.13 周二 引言&#x1f349;句1: As they are expected to be hungry after their long journey, food is laid out for them.成分划分弱读连读爆破语调 &#x1f349;句2: Specially-made lanterns are hung outside each…

ASEMI代理光宝高速光耦LTV-6341特征,LTV-6341应用

编辑-Z LTV-6341参数描述&#xff1a; 型号&#xff1a;LTV-6341 储存温度Tstg&#xff1a;-55~ 150℃ 工作温度Topr&#xff1a;-40~ 125℃ 总输出电源电压(VCC –VEE)&#xff1a;35V 平均正向输入电流IF&#xff1a;25mA 反向输入电压VR&#xff1a;5V 输入电流&…

第15章_锁

第15章_锁 事务的 隔离性 由这章讲述的 锁 来实现。 1. 概述 锁是计算机协调多个进程或线程并发访问某一资源的机制。在程序开发中会存在多线程同步的问题&#xff0c;当多个线程并发访问某个数据的时候&#xff0c;尤其是针对一些敏感的数据&#xff08;比如订单、金额等)&…

老板喜欢表现型管理者,而不是实干型管理者?

最近热搜榜&#xff1a;月薪几万运营总监只会管鸡毛蒜皮 很多老板在招聘方面往往会有些着急&#xff0c;他们可能会把同样的项目交给两个团队去完成&#xff0c;然后比较两个团队的表现。 其中&#xff0c;t1团队的负责人老王&#xff0c;整天忙于拍视频、发朋友圈、写汇报&am…

2023年江西省赣州市职业院校技能大赛(中职组) 网络安全竞赛试题(6月17日竞赛真题))

2023年江西省赣州市职业院校技能大赛&#xff08;中职组&#xff09; 网络安全竞赛试题 三、竞赛任务书内容 &#xff08;一&#xff09;拓扑图 &#xff08;二&#xff09;A模块基础设施设置/安全加固&#xff08;200分&#xff09; 一、项目和任务描述&#xff1a; 假定你…

宾利添越升级ACC自适应巡航+抬头显示HUD+Naim音响案例分享

大家好&#xff0c;我是小志bzs878&#xff0c;专注名车原厂升级&#xff0c;欢迎戳戳右上角“”号关注一下&#xff0c;持续为您带来精彩改装案例 今天装车一台宾利添越&#xff0c;几百个W的气场非常强大的豪车还需要加装什么项目&#xff1f; 车子还未上牌&#xff0c;今天…

python---------xpath提取数据------打破局限

作者前言 欢迎小可爱们前来借鉴我的gtiee秦老大大 (qin-laoda) - Gitee.com 目录 为什么要学习XPATH和LXML类库 什么是XPATH 认识XML XML的节点关系 常⽤节点选择⼯具 节点选择语法 节点修饰语法 选择未知节点 lxml库 _____________________________________________…