栏目分类:
子分类:
返回
文库吧用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
文库吧 > IT > 软件开发 > 后端开发 > Python

玩转3D--入门(pygame)

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

玩转3D--入门(pygame)

全代码展示,讲解看下篇博客

exe免费纯享版地址:https://download.csdn.net/download/jianmuhuayi/26050493

import pygame
from pygame.locals import *
from sys import exit
from math import cos,sin,tan,radians
pygame.init()
p={}
width=600
color=(0,0,0)
fov=70
focus=(width/2)/tan(radians(fov/2))
screen = pygame.display.set_mode((width, width), 0,0)
screen.fill((255,255,255))
pygame.display.set_caption('3D project')
pygame.mouse.set_visible(False)
pygame.event.set_grab(True)
p['pa']=[-500,-500,800]
p['pb']=[-500,500,800]
p['pc']=[500,500,800]
p['pd']=[500,-500,800]
p['pe']=[-500,-500,1800]
p['pf']=[-500,500,1800]
p['pg']=[500,500,1800]
p['ph']=[500,-500,1800]
def rotatex(angle_x):
    for coordinate in p.values():
        coordinate_z_new=coordinate[2]*cos(angle_x)+coordinate[1]*sin(angle_x)
        coordinate_y_new=coordinate[1]*cos(angle_x)-coordinate[2]*sin(angle_x)
        coordinate[1]=coordinate_y_new
        coordinate[2]=coordinate_z_new
def rotatey(angle_x):
    for coordinate in p.values():
        coordinate_x_new=coordinate[0]*cos(angle_x)-coordinate[2]*sin(angle_x)
        coordinate_z_new=coordinate[2]*cos(angle_x)+coordinate[0]*sin(angle_x)
        coordinate[0]=coordinate_x_new
        coordinate[2]=coordinate_z_new
def bjo(p_a,p_b):
    global focus
    global color
    if focus<=p_a[2]:
        if focus<=p_b[2]:
            pygame.draw.aaline(screen,color,(p_a[0]/p_a[2]*focus+300, 300-p_a[1]/p_a[2]*focus), (p_b[0]/p_b[2]*focus+300 ,300-p_b[1]/p_b[2]*focus))
        else:
            pygame.draw.aaline(screen,color,((focus-p_a[2])*(p_b[0]-p_a[0])/(p_b[2]-p_a[2])+p_a[0]+300,300-((focus-p_a[2])*(p_b[1]-p_a[1])/(p_b[2]-p_a[2])+p_a[1])), (p_a[0]/p_a[2]*focus+300, 300-p_a[1]/p_a[2]*focus))
    else:
        if focus<=p_b[2]:
            pygame.draw.aaline(screen,color,((focus-p_a[2])*(p_b[0]-p_a[0])/(p_b[2]-p_a[2])+p_a[0]+300,300-((focus-p_a[2])*(p_b[1]-p_a[1])/(p_b[2]-p_a[2])+p_a[1])), (p_b[0]/p_b[2]*focus+300, 300-p_b[1]/p_b[2]*focus))
while True:
    for event in pygame.event.get():
        if event.type == KEYDOWN:
                if event.key == K_ESCAPE:
                    exit()
    screen.fill((255,255,255))
    pressed_keys = pygame.key.get_pressed()
    if True:
        mouse=pygame.mouse.get_rel()
        y=radians(mouse[0]/width*180)
        x=-radians(mouse[1]/width*180)
    else:
        x=0
        y=0
    rotatey(y)
    rotatex(x)
    if pressed_keys[K_a]:
            for coordinate in p.values():
                coordinate[0]+=1
    elif pressed_keys[K_d]:
            for coordinate in p.values():
                coordinate[0]-=1

    if pressed_keys[K_w]:
            for coordinate in p.values():
                coordinate[2]-=1
    elif pressed_keys[K_s]:
             for coordinate in p.values():
                coordinate[2]+=1
    bjo(p['pa'],p['pb'])
    bjo(p['pb'],p['pc'])
    bjo(p['pc'],p['pd'])
    bjo(p['pd'],p['pa'])
    bjo(p['pe'],p['pf'])
    bjo(p['pf'],p['pg'])
    bjo(p['pg'],p['ph'])
    bjo(p['ph'],p['pe'])
    bjo(p['pa'],p['pe'])
    bjo(p['pb'],p['pf'])
    bjo(p['pc'],p['pg'])
    bjo(p['pd'],p['ph'])
    pygame.display.update()

转载请注明:文章转载自 www.wk8.com.cn
本文地址:https://www.wk8.com.cn/it/280143.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 wk8.com.cn

ICP备案号:晋ICP备2021003244-6号