pygame单图伪3d

python 复制代码
import cv2
import pygame
import sys
from pygame import gfxdraw
import numpy as np

(width, height) = (800, 600)
pygame.init()
screen = pygame.display.set_mode((width, height))
image = pygame.image.load("11.jpg").convert()
d3=pygame.surfarray.array3d(image)
f=250#数字大会显示更前面的图片
sc=300#数字越大视角越高
color=(255, 255, 255)
#print(len(d3[0][0]))#len(d3 )就是有多少张表 一个[0]是有多高 两个是每个表有几列 三个就是具体数
#print(d3[0][0][0])
#print(d3)
#sarray=pygame.surfarray.array3d(pygame.surface((50,50)))
sarray=pygame.surfarray.array3d(pygame.Surface((width,height)))
#sarray[:]=(255,255,0)变成黄色,替换所有为(255,255,0)

tsize=image.get_size()#图片宽高
print(tsize)
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)  # 点击坐标
    for i in range(width):
        for j in range(int(height/2),height):
            x=(width/2)-i
            y=j+f
            z=j-(height/2)+0.01
            '''
            def huizhi(x, y, z):
            shiju = 300
            x1 = shiju * x / z
            y1 = shiju * y / z
            # p.append((x1,y1))
            return x1, y1
            '''
            px=x/z*sc
            py=y/z*90
            '''不重复图片'''
            #print(px, py)

            if 0 <= px < tsize[0] and 0 <= py< tsize[1]:
                #print(px, py)
                fp = int(px), int(py)
                #fc = d3[fp]
                #sarray[-i, j] = fc
                pygame.Surface.set_at(screen, (i, int(j/2)+260), (image.get_at((fp))))
                #pygame.Surface.set_at(screen, (int(i * 0.5), int(j * 0.5)), (image.get_at((fp))))
            #fp=int(px%tsize[0]),int(py%tsize[1])#tsize【0】,【1】是图片宽高


    #pygame.surfarray.blit_array(screen,sarray)
    pygame.display.update()
相关推荐
在钱塘江1 分钟前
LangGraph构建Ai智能体-8-计划和执行架构-更多示例
人工智能·python
独行soc5 分钟前
2025年渗透测试面试题总结-15(题目+回答)
python·科技·docker·容器·面试·eureka
新启航光学频率梳16 分钟前
【新启航】飞机起落架外筒深孔型腔的测量方法 - 激光频率梳 3D 轮廓检测
科技·3d·制造
站大爷IP29 分钟前
Python3解释器深度解析与实战教程:从源码到性能优化的全路径探索
python
站大爷IP1 小时前
Go与Python爬虫实战对比:从开发效率到性能瓶颈的深度解析
python
猫头虎1 小时前
如何实现在多跳UDP传输场景,保证单文件和多文件完整传输的成功率?
java·开发语言·网络·python·网络协议·golang·udp
onejason1 小时前
利用 Python 爬虫获取淘宝商品评论实战指南
前端·后端·python
tkdsy0072 小时前
Python调用C/C++函数库的多种方法与实践指南
python·c/c++·pybind11·swig·ctypes·cffi·python/c api
计算机毕设-小月哥2 小时前
【限时分享:Hadoop+Spark+Vue技术栈电信客服数据分析系统完整实现方案
大数据·vue.js·hadoop·python·信息可视化·spark·计算机毕业设计
跟橙姐学代码2 小时前
程序员都爱的小秘密:init.py 到底凭啥这么重要?
前端·python