设计自己的软渲染器3-渲染线框模型

2023-10-31 16:30

本文主要是介绍设计自己的软渲染器3-渲染线框模型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这一部分,我们将实现线框模型的显示与渲染,实际上就是把点连接起来。

画线算法很多,我在这里介绍经典的画线算法:

Bresenham快速画直线算法

直线光栅化是指用像素点来模拟直线,比如下图用蓝色的像素点来模拟红色的直线。


给定两个点起点P1(x1, y1), P2(x2, y2),line(p1,p2)的斜率为k,p1.x<p2.x,0<k<1

则,从p1开始,下一个点要么在他的右邻接点要么在他的右上邻接点,每次x++。如何选择这两个点呢,利用这两个近似点距离实际点的距离来算,即如果线段ax+by+c=0x=x1+1的交点的y坐标大于(y+*y+1))/2则选右上邻接点,否则选择右邻接点,如此重复便可画完一条直线。同理当1<k<inf时,每次y++,考察x

这样我们可以得到第一象限的所有直线画法。其实剩余的其他象限的直线画法于第一象限类似。

 

 

实现代码:(openGL四象限画直线)

void MyLine(int xs, int ys, int xe, int ye)

{

      //Write your code here

      intx,y,p;

      intdx = xe - xs;

      intdy = ye -ys;

     

      x =xs;

      y =ys;

      p =2 * dy - dx;

     

      if(abs(xe- xs) != 0 && abs(ye - ys) / abs(xe - xs) < 1)// K < 1

      {

           if(dx > 0 && dy >= 0 || dx < 0 && dy <= 0) {

                 if(dx< 0 && dy <= 0) {

                      dx= -dx;

                       dy = -dy;

                      x= xe;

                      y= ye;

                 }

                 glBegin(GL_POINTS);

                 for(inti = 0 ; i < dx ; i ++)

                 {

                      glVertex2i(x,y);

                      x++;

                      if( p < 0 )

                      {

                            p+= 2*dy;

                      }

                      else

                      {

                            y++;

                            p+= 2 * dy - 2 * dx;

                      }

                 }

                 glEnd();

            }

           elseif (dx > 0 && dy <= 0 || dx < 0 && dy >= 0){   

                 if(dx< 0 && dy >= 0) {

                      dx= -dx;

                      dy= -dy;

                      x= xe;

                      y= ye;

                 }

                 dy= -dy;

                 glBegin(GL_POINTS);

                 for(inti = 0 ; i < dx ; i ++)

                 {

                      glVertex2i(x,y);

                      x++;

                      if( p < 0 )

                      {

                            p+= 2*dy;

                      }

                      else

                      {

                            y--;

                            p+= 2 * dy - 2 * dx;

                      }

                 }

                 glEnd();

           }

          

          

      }

      else//K> 1

      {

           if(dx >= 0 && dy >= 0 || dx <= 0 && dy <= 0)

           {

                 if(dx<= 0 && dy <= 0) {

                      dx= -dx;

                      dy= -dy;

                      x= xe;

                      y= ye;

                 }

                 glBegin(GL_POINTS);

                 for(inti = 0 ; i < dy ; i ++)

                 {

                      glVertex2i(x,y);

                      y++;

                      if( p < 0 )

                      {

                            p+= 2*dx;

                      }

                      else

                      {

                            x++;

                            p+= 2 * dx - 2 * dy;

                      }

                 }

                 glEnd();

           }

           elseif (dx > 0 && dy <= 0 || dx < 0 && dy >= 0)

           {

                 if(dx < 0 && dy >= 0) {

                      dx= -dx;

                      dy= -dy;

                      x= xe;

                      y= ye;

                 }

                 dy= -dy;

                 glBegin(GL_POINTS);

                 for(inti = 0 ; i < dy ; i ++)

                 {

                      glVertex2i(x,y);

                      y--;

                      if( p < 0 )

                      {

                            p += 2*dx;

                      }

                      else

                      {

                            x++;

                            p+= 2 * dx - 2 * dy;

                      }

                 }

                 glEnd();

           }

          

          

      }   

}

 

但是我们在这里,只需要在第一象限画线,可以简化为下面

voidDrawLine(intxs, int ys, int xe,int ye,UINT32color) {

        // Bresenham line algorithm

        int dx = abs(xe -xs);

        int dy = abs(ye -ys);

        int sx = (xs <xe) ? 1 : -1;

        int sy = (ys <ye) ? 1 : -1;

        int err = dx - dy;

 

        while (true) {

            PutPixel(xs, ys, color);

 

            if ((xs ==xe) && (ys == ye)) break;

            int e2 = 2 * err;

            if (e2 > -dy) { err-= dy;xs += sx;}

            if (e2 < dx) { err+= dx;ys += sy;}

        }

}

 

我们在mesh中加入face表示其拥有的三角形面。

 

效果图


这篇关于设计自己的软渲染器3-渲染线框模型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/316648

相关文章

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

图神经网络模型介绍(1)

我们将图神经网络分为基于谱域的模型和基于空域的模型,并按照发展顺序详解每个类别中的重要模型。 1.1基于谱域的图神经网络         谱域上的图卷积在图学习迈向深度学习的发展历程中起到了关键的作用。本节主要介绍三个具有代表性的谱域图神经网络:谱图卷积网络、切比雪夫网络和图卷积网络。 (1)谱图卷积网络 卷积定理:函数卷积的傅里叶变换是函数傅里叶变换的乘积,即F{f*g}

秋招最新大模型算法面试,熬夜都要肝完它

💥大家在面试大模型LLM这个板块的时候,不知道面试完会不会复盘、总结,做笔记的习惯,这份大模型算法岗面试八股笔记也帮助不少人拿到过offer ✨对于面试大模型算法工程师会有一定的帮助,都附有完整答案,熬夜也要看完,祝大家一臂之力 这份《大模型算法工程师面试题》已经上传CSDN,还有完整版的大模型 AI 学习资料,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

怎么让1台电脑共享给7人同时流畅设计

在当今的创意设计与数字内容生产领域,图形工作站以其强大的计算能力、专业的图形处理能力和稳定的系统性能,成为了众多设计师、动画师、视频编辑师等创意工作者的必备工具。 设计团队面临资源有限,比如只有一台高性能电脑时,如何高效地让七人同时流畅地进行设计工作,便成为了一个亟待解决的问题。 一、硬件升级与配置 1.高性能处理器(CPU):选择多核、高线程的处理器,例如Intel的至强系列或AMD的Ry