Форум программистов, компьютерный форум, киберфорум
Python: GUI, графика
Войти
Регистрация
Восстановить пароль
 
0 / 0 / 0
Регистрация: 02.12.2016
Сообщений: 22
1
Tkinter

Переделать пирамиду в параллелепипед

20.01.2021, 17:44. Просмотров 998. Ответов 0

Помогите! Нужно переделать пирамиду в параллелепипед.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
from tkinter import Tk, Canvas
import numpy as np
 
 
# Колір заливки грані
def trColor(cn, step):
    ci = int(step) % 255
    if ci < 16:
        if cn == 0:
            return '#0' + hex(ci)[2:4] + '0000'
        elif cn == 1:
            return '#000' + hex(ci)[2:4] + '00'
        elif cn == 2:
            return '#00000' + hex(ci)[2:4]
        else:
            return '#000' + hex(ci)[2:4] + '0' + hex(ci)[2:4]
    else:
        if cn == 0:
            return '#' + hex(ci)[2:4] + '0000'
        elif cn == 1:
            return '#00' + hex(ci)[2:4] + '00'
        elif cn == 2:
            return '#0000' + hex(ci)[2:4]
        else:
            return '#00' + hex(ci)[2:4] + hex(ci)[2:4]
 
 
# Матриця переміщення на площині
def Move(p, dx, dy):
    return np.matmul([p[0], p[1], 1], np.array([[1, 0, 1],
                                                [0, 1, 0],
                                                [dx, dy, 1]]))
 
 
# Матриця повороту навколо осі Z
def Tz(psi):
    return np.array([[np.cos(psi), np.sin(psi), 0, 0],
                     [-np.sin(psi), np.cos(psi), 0, 0],
                     [0, 0, 1, 0],
                     [0, 0, 0, 1]])
 
 
# Загальна аксонометрична проекція
def AxonProjection(p, u, v):
    return np.matmul(p, np.matmul(np.array([[-np.cos(u), 0, np.sin(u), 0],
                                            [0, 1, 0, 0],
                                            [-np.sin(u), 0, -np.cos(u), 0],
                                            [0, 0, 0, 0]]),
                                  np.array([[1, 0, 0, 0],
                                            [0, -np.cos(v), -np.sin(v), 0],
                                            [0, np.sin(v), -np.cos(v), 0],
                                            [0, 0, 0, 0]])))
 
 
root = Tk()
 
h = 200  # Висота піраміди
a = 200  # Довжина сторони основи піраміди
r = np.sqrt(a ** 2 / 2)  # Радіус описаного кола навколо основи піраміди
points = [[0, 0, h, 0]]  # Вершина піраміди
for i in range(0, 4):
    points.append([r * np.cos(i * np.pi / 2), r * np.sin(i * np.pi / 2), 0, 1])
canvas = Canvas(root, width=700, height=700, bg='black')
 
c = 255  # Початкове значення інтенсивності кольору
dc = 0.1  # Приріст інтенсивності кольору
phi = np.pi / 6  # 30 градусів
theta = np.pi / 4  # 45 градусів
while True:
    c = c + dc
    if c < 0 or c > 255:
        dc = -dc
    canvas.delete("all")
    tr = []  # грані піраміди
    for i in range(0, 4):
        tr.append([AxonProjection(points[0], phi, theta),
                   AxonProjection(points[i + 1], phi, theta),
                   AxonProjection(points[(i + 1) % 4 + 1], phi, theta)])
    for j in range(0, 4):
        plainPoints = []  # Вершини полігона грані
        for i in range(0, 3):
            plainPoints.append(Move(tr[j][i], 350, 350)[0])
            plainPoints.append(Move(tr[j][i], 350, 350)[1])
        canvas.create_polygon(plainPoints, fill=trColor(j, c))
    points = list(map(lambda x: np.matmul(x, Tz(0.001)), points))  # Поворот навколо висоти піраміди
    canvas.pack()
    root.update()
 
root.mainloop()
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
20.01.2021, 17:44
Ответы с готовыми решениями:

переделать параллелепипед на на призму с правильным девятиугольником в основании
Помогите переделать параллелепипед на на призму с правильным девятиугольником в основании вот...

Нарисовать пирамиду из решеток похожую на пирамиду
Задача: нужно нарисовать пирамиду из решеток похожую на пирамиду , на которую взбирается Марио в...

Параллелепипед
В прямом параллелепипеде основаниями ABCD и A1B1C1D1 DC=8, C1=6 ; уголА=60. Найдите площадь полной...

Параллелепипед
Есть небольшая задача построить параллелепипед с развертки как на фото, хоть в GLU и нет готовых...

0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
20.01.2021, 17:44

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Многомерный параллелепипед
доказать, что диагональ n-мерного параллелепипеда делится на n равных частей точками пересечения ее...

Класс параллелепипед
На вход подается некоторое количество параллелепипедов (координаты вершин). Отсортировать и вывести...

Параллелепипед и куб
Здравствуйте, помоги пожалуйста с задачей. Только начинаю разбираться в джаве. Даны длины сторон...

Светящийся параллелепипед
Задача следующая. Имеется трехмерная прямоугольная сетка, ребра вдоль осей xyz. Каждой ячейке...

Построить параллелепипед
Как построить просто параллелепипед с помощью drawline или drawrectangle и двигать его?

Класс Параллелепипед
Составить описание класса прямоугольного параллелепипеда со сторонами, параллельными осям...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.