专栏中心

EEPW首页 > 专栏 > 如何用 OpenGL 绘制雪花?

如何用 OpenGL 绘制雪花?

发布人:AI科技大本营 时间:2022-02-12 来源:工程师 发布文章

作者 | 许向武       

责编 | 张红月

出品 | CSDN博客

看冬奥才知道,阿勒泰不但是中国的“雪都”,还是“人类滑雪起源地”。这个说法是否成立,姑且不论,阿勒泰的雪的确很漂亮。冬奥会有一个宣传片,就是借用一朵阿勒泰雪花的视角来讲述冬奥会的故事,既有历史的厚重,又有艺术的浪漫,极具视觉冲击感。

那么问题来了:如何用OpenGL绘制雪花呢?通常,点精灵(point sprite)技术被用于描述大量粒子在屏幕上的运动,自然也可以用于绘制雪花。点精灵可以理解为贴了纹理图片的点——仅用一个vertex就可以把一个2D纹理图片绘制到屏幕的任何位置。

在OpenGL中开启和使用点精灵有一点点复杂,好在WxGL对此做了封装,用起来非常简单。在给出演示代码前,先贴两张雪花的纹理图片。

熟悉GLSL语言的同学,很容易读懂着色器源码。将着色器源码、纹理图片装进模型之后,只需要show一下,雪花就显示出来了。如果想实现雪花飘飘的效果,请参考我的另一篇博文《用OpenGL导演一场烟花盛会,迎接即将到来的新年》(https://xufive.blog.csdn.net/article/details/122743824)。

好了,话不多说,直接上绘制雪花的代码:

import numpy as np
import wxgl
from wxgl import wxplot as plt
vshader_src = """
    #version 330 core
    in vec4 a_Position;
    uniform mat4 u_MVPMatrix;
    void main() { 
        gl_Position = u_MVPMatrix * a_Position; 
        gl_PointSize = (a_Position.z + 1) * 30;
    }
"""
fshader_src = """
    #version 330 core
    uniform sampler2D u_Snow_1;
    in float idx;
    void main() { 
        gl_FragColor = texture2D(u_Snow_1, gl_PointCoord); 
    } 
"""
m = wxgl.Model(wxgl.POINTS, vshader_src, fshader_src, sprite=True) # 通过sprite=Treue开启点精灵
m.set_vertex('a_Position', np.random.random((300, 3))*2-1) # 随机生成300个点
m.add_texture('u_Snow_1', 'res/image/snow_1.png', wxgl.TEXTURE_2D) # 添加雪花纹理
m.set_mvp_matrix('u_MVPMatrix') # 设置模型矩阵、视点矩阵和投影矩阵
plt.model(m)
plt.show()

下面是使用snow_1.png做纹理的效果。

微信图片_20220212153758.jpg

下面是使用snow_2.png做纹理的效果。

微信图片_20220212153821.jpg

不过,这样的雪花略显单调,毕竟,世界上没有两片完全相同的雪花。怎样让雪花看起来更逼真一点呢?下面的代码尝试在片元着色器中混用两种纹理。

import numpy as np
import wxgl
from wxgl import wxplot as plt
vshader_src = """
    #version 330 core
    in vec4 a_Position;
    uniform mat4 u_MVPMatrix;
    void main() { 
        gl_Position = u_MVPMatrix * a_Position; 
        gl_PointSize = (a_Position.z + 1) * 30;
    }
"""
fshader_src = """
    #version 330 core
    uniform sampler2D u_Snow_1;
    uniform sampler2D u_Snow_2;
    in float idx;
    void main() { 
        if (fract(sin(dot(gl_PointCoord ,vec2(12.9898,78.233))) * 43758.5453) < 0.5) {
            gl_FragColor = texture2D(u_Snow_1, gl_PointCoord); 
        } else {
            gl_FragColor = texture2D(u_Snow_2, gl_PointCoord);
        }
    } 
"""
m = wxgl.Model(wxgl.POINTS, vshader_src, fshader_src, sprite=True) # 通过sprite=Treue开启点精灵
m.set_vertex('a_Position', np.random.random((300, 3))*2-1) # 随机生成300个点
m.add_texture('u_Snow_1', 'res/image/snow_1.png', wxgl.TEXTURE_2D) # 添加雪花纹理1
m.add_texture('u_Snow_2', 'res/image/snow_2.png', wxgl.TEXTURE_2D) # 添加雪花纹理2
m.set_mvp_matrix('u_MVPMatrix') # 设置模型矩阵、视点矩阵和投影矩阵
plt.model(m)
plt.show()

这个雪花有点独特吧?

微信图片_20220212153838.jpg

专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们

关键词: AI

相关推荐

AI催生“芯片通胀”:2D NAND价格失控,300%涨幅背后的行业博弈

2026-05-19

AI聊天机器人能像医生一样推理吗?

AI/HPC新世代 COUPE光互连扮要角

网络与存储 2026-05-15

国家“算力网”:像用水用电一样用AI

2026-05-18

存储器转型AI战略资源 台厂受惠

网络与存储 2026-05-19

基于Microchip MCU的AI/ML培训教程3

视频 2025-11-12

基于Microchip MCU的AI/ML培训教程2

视频 2025-11-12

被动元件新周期:AI时代高端化、服务器化重构MLCC产业格局

基于Microchip MCU的AI/ML培训教程1

视频 2025-11-12

CSR8670CSR8675智能语音Alexa蓝牙方案开发

资源下载 2017-12-14

思科凭借通用商用芯片与光模块赢得 AI 领域客户

研华科技与Axelera AI深化战略合作 加速推动基于Europa平台的边缘AI创新

EEPW2018年6月刊(5G)

资源下载 2018-06-11

EEPW2018年3月刊(工业物联网)

尼吉康的事业介绍

视频 2025-07-25

联发科加速AI在地化应用布局

智能计算 2026-05-19

电子元件培训教材

重新构想AI电源:塑造AI加速的未来(第三部分)

PowiGaN for AI Data Centers: Unmatched Power Density and Reliability

视频 2025-12-19
更多 培训课堂
更多 焦点
更多 视频

技术专区