作者 | 许向武

责编 | 张红月

出品 | 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 pltvshader_src = """#version 330 corein 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 coreuniform 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 np
import wxgl
from wxgl import wxplot as pltvshader_src = """#version 330 corein 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 coreuniform 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()

这个雪花有点独特吧?

资讯

谷歌使出禁用2G大招

资讯

大型模型语言能够理解吗?

技术

Python写了一个网页版的P图软件

技术

11款可替代top命令的工具!

分享

点收藏

点点赞

点在看

如何用 OpenGL 绘制雪花?相关推荐

  1. 如何用OpenGL的点精灵(point sprite)绘制雪花?

    看冬奥才知道,阿勒泰不但是中国的"雪都",还是"人类滑雪起源地".这个说法是否成立,姑且不论,阿勒泰的雪的确很漂亮.冬奥会有一个宣传片,就是借用一朵阿勒泰雪花的 ...

  2. 【图形基础篇】04 # GPU与渲染管线:如何用WebGL绘制最简单的几何图形?

    说明 [跟月影学可视化]学习笔记. 图形系统是如何绘图的? 一个通用计算机图形系统主要包括 6 个部分,分别是: 输入设备 中央处理单元:首先,数据经过 CPU 处理,成为具有特定结构的几何信息. 图 ...

  3. 怎样用python画雪花_python使用turtle库与random库绘制雪花

    本文实例为大家分享了python绘制雪花的具体代码,供大家参考,具体内容如下 代码非常容易理解,画着玩玩还是可以的.直接上代码 # -*- coding: utf-8 -*- "" ...

  4. HTML5 canvas绘制雪花飘落

    Canvas是HTML5新增的组件,它就像一块幕布,可以用JavaScript在上面绘制各种图表.动画等.没有Canvas的年代,绘图只能借助Flash插件实现,页面不得不用JavaScript和Fl ...

  5. 中国电子学会图形化四级编程题:绘制雪花

    「青少年编程竞赛交流群」已成立(适合6至18周岁的青少年),公众号后台回复[Scratch]或[Python],即可进入.如果加入了之前的社群不需要重复加入. 我们将有关编程题目的教学视频已经发布到抖 ...

  6. 使用OpenGL绘制圆环体(Torus)

    本篇介绍一下使用OpenGL绘制圆环体的方法.程序是在C#和OpenTK环境下编译的. 代码: /// <summary> /// 绘制圆环体 /// </summary> / ...

  7. python画树叶-手把手|如何用Python绘制JS地图?

    原标题:手把手|如何用Python绘制JS地图? 关于转载授授权 大数据文摘作品,欢迎个人转发朋友圈,自媒体.媒体.机构转载务必申请授权,后台留言"机构名称+文章标题+转载",申请 ...

  8. 用python绘制柱状图标题-如何用Python绘制3D柱形图

    本文主要讲解如何使用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 2 ...

  9. 用python画雪花-python使用turtle库与random库绘制雪花

    本文实例为大家分享了python绘制雪花的具体代码,供大家参考,具体内容如下 代码非常容易理解,画着玩玩还是可以的.直接上代码 # -*- coding: utf-8 -*- "" ...

最新文章

  1. 图文并茂!60页PPT《快速入门python数据分析路线》(附链接)
  2. python statsmodel 回归结果提取
  3. 并发编程之Synchronized原理
  4. [转]asp.net权限认证:摘要认证(digest authentication)
  5. VTK:图片之ImageCorrelation
  6. Redis中的Sentinel 验证
  7. 内网访问不到内网网站问题和不用端口号访问网站问题
  8. java .vm h2_java-H2服务器在调试时挂起
  9. 【计算机网络】为什么一个路由器会有两个wifi信号
  10. java界面的this_jsp中的this
  11. 【笔记】《编写高质量代码:改善c#程序的157个建议》-第1章 基本语言要素(SamWang)...
  12. 金山盛大成立合资公司
  13. python娃娃在地上摆积木_Python中乐高积木——函数
  14. hub设备_五年内任何问题,直接换新,毕亚兹 USB3.0四口HUB分线器体验
  15. 零基础Matlab Note9--离散数据绘图set(gca, )
  16. win7网络发现启用后找不到网络计算机,win7启用网络发现怎么又关闭了怎么解决...
  17. Verilog always和assign知识点
  18. Artemis客户端安装
  19. 使用jol查看对象内部布局
  20. 【解惑】杨中科说给弟弟的话

热门文章

  1. 学python培训到底能干嘛
  2. c#中接口的使用方法图解_C#图解教程 第十五章 接口
  3. React + Koa 实现服务端渲染(SSR)
  4. javascript promise编程
  5. Spring中使用Log4j记录日志
  6. js调用ios的方法
  7. one pragmatical sqlhelper
  8. MySQL两主多从,且故障转移配置
  9. 关于RAID与SCSI的一些基本概念(转)
  10. Python库glob学习笔记