NeHe OpenGL Lesson37 – Cel-Shading(卡通渲染)
This sample shows us how to do Cel-Shading with OpenGL. The cel-shading contain two part: one is the color grading on the object surface; the other one is the outline effect.
To get the color grading effect, we usually use the brightness of vertex as the vertex texture coordinates to sample a 1D texture that already color graded. The method that used in this sample is calculating the dot product between the triangle surface normal and light direction, take the result as the texture coordinates value. A 1d texture that already color graded may like following:
As you see, some range will fall into one fix color. This will make the object surface appears to be color grading. The texture coordinates calculating process is on fly, we will do the computation on every frame. Of course, you could provide paint it with color by command glColor3f, just as the screen shot, I gave it a blue color.
To get the outline effect. At first, we define the outline are the edges between front surfaces and back surfaces. So we just draw the back surfaces with wireframe mode, and less or equal for the depth comparing function. Of source, some options like set the line color, or width also be provided here with OpenGL commands.
The full source code could be checked from here.
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
· 上周热点回顾(2.17-2.23)