如何用OpenGL绘制雪花?

2022 年 2 月 7 日 CSDN

作者 | 许向武        责编 | 张红月
出品 | CSDN博客

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

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

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

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

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

import numpy as npimport wxglfrom 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做纹理的效果。

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

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

import numpy as npimport wxglfrom 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) # 添加雪花纹理1m.add_texture('u_Snow_2', 'res/image/snow_2.png', wxgl.TEXTURE_2D) # 添加雪花纹理2m.set_mvp_matrix('u_MVPMatrix') # 设置模型矩阵、视点矩阵和投影矩阵
plt.model(m)plt.show()

这个雪花有点独特吧?


新程序员003》正式上市,50余位技术专家共同创作,云原生和数字化的开发者们的一本技术精选图书。内容既有发展趋势及方法论结构,华为、阿里、字节跳动、网易、快手、微软、亚马逊、英特尔、西门子、施耐德等30多家知名公司云原生和数字化一手实战经验!

   
   
     
华为拿百亿资金给员工分红,每股1.58元;苹果将推出M2芯片入门级MacBook Pro;Flutter 2.10发布|极客头条
从个人英雄到万能开发者,程序员3.0时代到来
2021年C++项目中的十大Bug:乍一看都正确的代码,实则暗藏玄机!
登录查看更多
0

相关内容

OpenGL(Open Graphics Library)是个定义了一个跨编程语言、跨平台的编程接口的规格,它用于生成二维、三维图像。
如何用latext画神经网络?这个PlotNeuralNet能帮到你
专知会员服务
25+阅读 · 2022年1月15日
【2021新书】面向对象的Python编程,418页pdf
专知会员服务
70+阅读 · 2021年12月15日
基于流线的流场可视化绘制方法综述
专知会员服务
26+阅读 · 2021年12月9日
【博士论文】多视光场光线空间几何模型研究
专知会员服务
22+阅读 · 2021年12月6日
专知会员服务
25+阅读 · 2021年8月11日
【干货书】Python参考手册,210页pdf
专知会员服务
63+阅读 · 2021年4月30日
如何撰写好你的博士论文?CMU-Priya博士这30页ppt为你指点
专知会员服务
56+阅读 · 2020年10月30日
pytorch提取参数及自定义初始化
极市平台
0+阅读 · 2022年4月13日
Solid.js 就是我理想中的 React
InfoQ
0+阅读 · 2022年3月20日
实操教程|OpenCV中保存不同深度图像的技巧
极市平台
0+阅读 · 2022年2月14日
强化学习扫盲贴:从Q-learning到DQN
夕小瑶的卖萌屋
52+阅读 · 2019年10月13日
【材料课堂】EBSD晶体学织构基础及数据处理
材料科学与工程
34+阅读 · 2018年7月14日
用Python制作3D动画
Python程序员
30+阅读 · 2018年1月17日
如何用TensorFlow和TF-Slim实现图像标注、分类与分割
北京思腾合力科技有限公司
21+阅读 · 2017年11月24日
国家自然科学基金
1+阅读 · 2013年12月31日
国家自然科学基金
0+阅读 · 2013年12月31日
国家自然科学基金
0+阅读 · 2013年12月31日
国家自然科学基金
2+阅读 · 2012年12月31日
国家自然科学基金
0+阅读 · 2012年12月31日
国家自然科学基金
0+阅读 · 2011年12月31日
国家自然科学基金
0+阅读 · 2011年12月31日
国家自然科学基金
2+阅读 · 2010年12月31日
Arxiv
0+阅读 · 2022年4月19日
Differentiable Time-Frequency Scattering in Kymatio
Arxiv
0+阅读 · 2022年4月18日
Arxiv
0+阅读 · 2022年4月18日
Arxiv
0+阅读 · 2022年4月14日
VIP会员
相关VIP内容
相关资讯
pytorch提取参数及自定义初始化
极市平台
0+阅读 · 2022年4月13日
Solid.js 就是我理想中的 React
InfoQ
0+阅读 · 2022年3月20日
实操教程|OpenCV中保存不同深度图像的技巧
极市平台
0+阅读 · 2022年2月14日
强化学习扫盲贴:从Q-learning到DQN
夕小瑶的卖萌屋
52+阅读 · 2019年10月13日
【材料课堂】EBSD晶体学织构基础及数据处理
材料科学与工程
34+阅读 · 2018年7月14日
用Python制作3D动画
Python程序员
30+阅读 · 2018年1月17日
如何用TensorFlow和TF-Slim实现图像标注、分类与分割
北京思腾合力科技有限公司
21+阅读 · 2017年11月24日
相关基金
国家自然科学基金
1+阅读 · 2013年12月31日
国家自然科学基金
0+阅读 · 2013年12月31日
国家自然科学基金
0+阅读 · 2013年12月31日
国家自然科学基金
2+阅读 · 2012年12月31日
国家自然科学基金
0+阅读 · 2012年12月31日
国家自然科学基金
0+阅读 · 2011年12月31日
国家自然科学基金
0+阅读 · 2011年12月31日
国家自然科学基金
2+阅读 · 2010年12月31日
Top
微信扫码咨询专知VIP会员