Форум программистов, компьютерный форум, киберфорум
Python: GUI, графика
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
 Аватар для Larisa111
2 / 2 / 0
Регистрация: 14.12.2012
Сообщений: 227

Возможности python (3Д графика)

08.10.2020, 18:39. Показов 1529. Ответов 3

Студворк — интернет-сервис помощи студентам
здравствуйте, подскажите пожалуйста возможно ли и главное насколько рационально именно на python работать в 3d графике может есть специальные библиотеки плагины и тд
писать скрипты на питоне, например, чтобы особым образом искрился солнечный свет на воде, или там запрограммировать графические шейдеры (отображают особым образом графику) на проявление туманности в горных вершинах, преломление света сквозь дым и т.д.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.10.2020, 18:39
Ответы с готовыми решениями:

Возможности python
Я не знаком с python, но мне понадобилось написать одну программу. Так вот, программа нужна для работы с RDP. Скажите, эффективен ли...

Python возможности и обучение
Здравствуйте, имеется ряд вопросов по python, ответе пожалуйста! 1. Что может python? 2. Как у питона с GUI? 3. Возможно на питоне...

Возможности python-docx
Добрый день! Работал ли кто-нибудь с библиотекой python-docx(таблицы, заголовки, абзацы)? Планирую писать программу проверки оформления,...

3
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
08.10.2020, 18:53
Шейдеры на питоне писать, конечно, не получится.
3д графика - штука низкоуровневая, но Python является хорошим "клеем" для сборки готовых компонентов. Библиотек навалом. Так что выбирайте ваш движок. Для всех популярных имеются биндинги к питону.
1
5517 / 2870 / 571
Регистрация: 07.11.2019
Сообщений: 4,761
09.10.2020, 06:50
https://docs.blender.org/api/current/index.html
1
9948 / 2948 / 497
Регистрация: 05.10.2013
Сообщений: 8,019
Записей в блоге: 242
20.03.2021, 13:57
Larisa111, есть вам хочется ускориться в достижении своих целей, то можете взять Panda3D. Этот движок позволяет создавать интерактивные 3D приложения в короткий срок. Скорее всего, этот движок поддерживает те эффекты, которые вы перечислили. Если нет, то этот движок должен поддерживать написание своих шейдеров. Я иногда упражняюсь на этом движке.

Устанавливается так:

pip install Panda3D
Есть книги для начинающих в Panda3D на английском, которые несложно найти в сети.

У меня похожие задача, что вы перечислили. Всё что вы описали решается с помощью шейдеров. Я выбрал два фреймворка, в которые встроена поддержка шейдеров на языке GLSL: PyQt5 и PySide2. GLSL - это язык шейдеров для OpenGL, а OpenGL - расшифровывается как Open Graphics Library. PyQt5 и PySide2 очень сильно похожи. Я не знал, какой лучше выбрать, поэтом стал изучать оба. Я пока ещё осваиваю основы и не добрался до сложных графических эффектов, но это вполне осуществимо на GLSL. Для осваивания OpenGL и GLSL подойдут любые книги и туториалы на любых языках программирования. В основном это будет C++. Qt сильно упрощает работу с шейдерами и OpenGL. Например, чтобы скомпилировать шейдеры и создать шейдерную программу нужно всего лишь несколько строк кода:

Python
1
2
3
4
        program = QOpenGLShaderProgram(self)
        program.addShaderFromSourceCode(QOpenGLShader.Vertex, vertShaderSrc)
        program.addShaderFromSourceCode(QOpenGLShader.Fragment, fragShaderSrc)
        program.link()
Поставьте PyQt5 и всё необходимое командами:

pip install PyQt5
pip install PyOpenGL
pip install numpy
Кроме графики PyQt5 содержит множество полезных вещей: поддержка баз данных (например, SQLite из коробки), сеть, звук, математика, загрузка изображений, GUI и т.д.

Пример, как нарисовать треугольник на PyQt5/PySide2 и GLSL. Как нарисовать треугольник нужно знать наизусть, чтобы это было в голове, потому что из треугольников строятся все объекты на OpenGL/GLSL в 3D и в 2D:

PyQt5:

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
import sys
import numpy as np
from OpenGL import GL as gl
from PyQt5.QtWidgets import QOpenGLWidget, QApplication
from PyQt5.QtGui import (QOpenGLBuffer, QOpenGLShaderProgram,
    QOpenGLShader)
from PyQt5.QtCore import Qt
 
class OpenGLWidget(QOpenGLWidget):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("Triangle, PyQt5, OpenGL 3.3")
        self.resize(400, 400)
    def initializeGL(self):
        gl.glClearColor(0.5, 0.8, 0.7, 1.0)
        vertShaderSrc = """
            #version 330 core
            in vec3 aPosition;
            void main()
            {
                gl_Position = vec4(aPosition, 1.0);
            }
        """
        fragShaderSrc = """
            #version 330 core
            void main()
            {
                gl_FragColor = vec4(0.5, 0.2, 0.9, 1.0);
            }
        """
        program = QOpenGLShaderProgram(self)
        program.addShaderFromSourceCode(QOpenGLShader.Vertex, vertShaderSrc)
        program.addShaderFromSourceCode(QOpenGLShader.Fragment, fragShaderSrc)
        program.link()
        program.bind()
        vertPositions = np.array([
            -0.5, -0.5, 0.0,
            0.5, -0.5, 0.0,
            0.0, 0.5, 0.0], dtype=np.float32)
        self.vertPosBuffer = QOpenGLBuffer()
        self.vertPosBuffer.create()
        self.vertPosBuffer.bind()
        self.vertPosBuffer.allocate(vertPositions, len(vertPositions) * 4)
        program.bindAttributeLocation("aPosition", 0)
        program.setAttributeBuffer(0, gl.GL_FLOAT, 0, 3)
        program.enableAttributeArray(0)
 
    def paintGL(self):
        gl.glClear(gl.GL_COLOR_BUFFER_BIT)
        gl.glDrawArrays(gl.GL_TRIANGLES, 0, 3)
 
def main():
    QApplication.setAttribute(Qt.AA_UseDesktopOpenGL)
    a = QApplication(sys.argv)
    w = OpenGLWidget()
    w.show()
    sys.exit(a.exec_())
 
if __name__ == "__main__":
    main()
PySide2

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
import sys
import numpy as np
from OpenGL import GL as gl
from PySide2.QtWidgets import QOpenGLWidget, QApplication
from PySide2.QtGui import (QOpenGLBuffer, QOpenGLShaderProgram,
    QOpenGLShader)
from PySide2.QtCore import Qt
 
class OpenGLWidget(QOpenGLWidget):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("Triangle, PySide2, OpenGL 3.3")
        self.resize(400, 400)
    def initializeGL(self):
        gl.glClearColor(0.5, 0.8, 0.7, 1.0)
        vertShaderSrc = """
            #version 330 core
            in vec3 aPosition;
            void main()
            {
                gl_Position = vec4(aPosition, 1.0);
            }
        """
        fragShaderSrc = """
            #version 330 core
            void main()
            {
                gl_FragColor = vec4(0.5, 0.2, 0.9, 1.0);
            }
        """
        program = QOpenGLShaderProgram(self)
        program.addShaderFromSourceCode(QOpenGLShader.Vertex, vertShaderSrc)
        program.addShaderFromSourceCode(QOpenGLShader.Fragment, fragShaderSrc)
        program.link()
        program.bind()
        vertPositions = np.array([
            -0.5, -0.5, 0.0,
            0.5, -0.5, 0.0,
            0.0, 0.5, 0.0], dtype=np.float32)
        self.vertPosBuffer = QOpenGLBuffer()
        self.vertPosBuffer.create()
        self.vertPosBuffer.bind()
        self.vertPosBuffer.allocate(vertPositions, len(vertPositions) * 4)
        program.bindAttributeLocation("aPosition", 0)
        program.setAttributeBuffer(0, gl.GL_FLOAT, 0, 3)
        program.enableAttributeArray(0)
 
    def paintGL(self):
        gl.glClear(gl.GL_COLOR_BUFFER_BIT)
        gl.glDrawArrays(gl.GL_TRIANGLES, 0, 3)
 
def main():
    QApplication.setAttribute(Qt.AA_UseDesktopOpenGL)
    a = QApplication(sys.argv)
    w = OpenGLWidget()
    w.show()
    sys.exit(a.exec_())
 
if __name__ == "__main__":
    main()
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.03.2021, 13:57
Помогаю со студенческими работами здесь

Возможности Python для крупного сайта
Поставили задачу разработать сайт-хранилище с большим объёмом фотографий. Их может быть 10к - 30к. Кроме того, на сайте должен...

Возможности построения графика в зависимости от параметра
Здравствуйте, подскажите пожалуйста на счет возможности реализации подобной задачи. Сначала был параметр. Он был определен как константа...

Как изучить все возможности IDE VS2010, а особенно возможности дебаггера
Доброго времени суток. Вот хотелось бы изучить все возможности IDE VS2010, а особенно возможности дебаггера. Литературы много, а о самом...

Python. Графика
Помогите, я недавно начал программировать на языке Python. Я начал делать приложение с графикой, но никак не могу найти чтобы при нажатии...

Графика в Python
Помогите пожалуйста нарисовать данное изображение в Python Pillow. Я не ориентируюсь в данной области программирования)))


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru