当前位置: 首页 > news >正文

基于x-scan扫描线的3D模型渲染算法

基于x-scan算法实现的z-buffer染色。c#语言,.net core framework 3.1运行。

模型是读取3D Max的obj模型。

x-scan算法实现:

public List<Vertex3> xscan() {List<Vertex3> results = new List<Vertex3>();SurfaceFormula formula = getFormula();Box rect = getBound();for (int y = rect.IntMinY; y <= rect.IntMaxY; y++) {List<double> set = new List<double>();for (int i = 0; i < this.vectex.Length; i++) {Vertex3 v1 = this.vectex[i];Vertex3 v2 = this.vectex[(i + 1) % vectex.Length];if (v1.IntY == v2.IntY || y < Math.Min(v1.Y, v2.Y) || y > Math.Max(v1.Y,v2.Y ))continue;LineFormula formula1 = new LineFormula(v1, v2);Double? x = formula1.getX(y);if (x != null) {bool e = false;foreach (double d in set) if (Math.Abs(d - x.Value) < 0.005)e = true;if (e == false)set.Add(x.Value);}}if (set.Count > 0 && set.Count % 2 == 0) {set.Sort();for (int i=0; i<set.Count-1; i++)for (int x = (int)set[i]; x <= (int) set[i + 1]; x++)results.Add(new Vertex3(x, y, formula.getZ(x, y)));}}return results;
}

z-buffer算法:

private List<Vertex3RGB> zbuffer(Model.Model model, Bitmap canvas) {int?[,] deep = new int?[canvas.Width, canvas.Height];Vertex3RGB[,] pixels = new Vertex3RGB[canvas.Width, canvas.Height];for (int i = 0; i < canvas.Width; i++)for (int j = 0; j < canvas.Height; j++)deep[i, j] = null;foreach (Surface surface in model.Surface){Vertex3 nv = surface.NormalVector();if (this.normalvector && nv.Z <= 0)continue;List<Vertex3> results = surface.xscan();foreach (Vertex3 v in results){if (v.IntX < 0 || v.IntX >= canvas.Width)continue;if (v.IntY < 0 || v.IntY >= canvas.Height)continue;if (deep[v.IntX, v.IntY] == null || v.IntZ > deep[v.IntX, v.IntY]){deep[v.IntX, v.IntY] = v.IntZ;pixels[v.IntX, v.IntY] = new Vertex3RGB(v, brushColor.ToArgb(), nv);}}}List<Vertex3RGB> r = new List<Vertex3RGB>();for (int i = 0; i < pixels.GetLength(0); i++)for (int j = 0; j < pixels.GetLength(1); j++)if (pixels[i, j] != null)r.Add(pixels[i, j]);return r;
}

原始模型如下(使用法相量):

 基于x-scan的zbuffer算法(使用法向量):

 基于x-scan光照渲染(使用法向量):

相关文章:

基于x-scan扫描线的3D模型渲染算法

基于x-scan算法实现的z-buffer染色。c#语言&#xff0c;.net core framework 3.1运行。 模型是读取3D Max的obj模型。 x-scan算法实现&#xff1a; public List<Vertex3> xscan() {List<Vertex3> results new List<Vertex3>();SurfaceFormula formula g…...

LeetCode36.Valid-Sudoku<有效的数独>

题目&#xff1a; 思路&#xff1a; 这题并不难&#xff0c;它类似于N皇后问题。在N皇后问题中&#xff0c;行&#xff0c;列&#xff0c;对角线&#xff0c;写对角线&#xff0c;都不能出现连续的皇后。 本题类似&#xff0c;不过他是行&#xff0c;列&#xff0c;还有一个B…...

Linux中的pause函数

2023年7月29日&#xff0c;周六上午 函数原型 在Linux中&#xff0c;pause()函数用于使当前进程暂停执行&#xff0c;直到接收到一个信号。 #include <unistd.h>int pause(void);pause()函数不接受任何参数。 通常&#xff0c;pause()函数用于编写简单的信号处理程序&…...

CommonCollections6链分析

前面和CC1一样 优点是不限制jdk版本和cc的版本 先开一个ChainedTransformer 然后创LazyMap 我们顺便执行一下避免上面写错 能弹计算器 没问题 后面就是CC6不同的地方了 我们需要一个TiedMapEntry 因为需要一个类调用了get方法 在TiedMapEntry的getValue()方法中调用了get()…...

优化基于tcp,socket的ftp文件传输程序

原始程序&#xff1a; template_ftp_server_old.py&#xff1a; import socket import json import struct import os import time import pymysql.cursorssoc socket.socket(socket.AF_INET, socket.SOCK_STREAM) HOST 192.168.31.111 PORT 4101 soc.bind((HOST,PORT)) p…...

MySQL 数据库 【增删查改(二)】

目录 一、表的设计 1、一对一 2、一对多 3、多对多 二、新增 三、查询 1、聚合查询 &#xff08;1&#xff09;聚合函数&#xff1a; &#xff08;2&#xff09; group by 子句 &#xff08;3&#xff09;having 2、联合查询 (1)内连接 (2)外连接 (3)自链接 (4)…...

力扣 -- 978. 最长湍流子数组

一、题目 二、解题步骤 下面是用动态规划的思想解决这道题的过程&#xff0c;相信各位小伙伴都能看懂并且掌握这道经典的动规题目滴。 三、参考代码 class Solution { public:int maxTurbulenceSize(vector<int>& nums) {int nnums.size();vector<int> f(n);…...

甘特图 Dhtmlx Gantt

介绍 在一些任务计划、日程进度等场景中我们会使用到甘特图&#xff0c;Dhtmlx Gantt 对于甘特图的实现支持很友好&#xff0c;文档API介绍全面&#xff0c;虽然增强版的收费&#xff0c;但免费版的足以够用。 官网&#xff1a;https://docs.dhtmlx.com/gantt/ 安装dhtml gannt…...

iOS 应用上架流程详解

iOS 应用上架流程详解 欢迎来到我的博客&#xff0c;今天我将为大家分享 iOS 应用上架的详细流程。在这个数字化时代&#xff0c;移动应用已经成为了人们生活中不可或缺的一部分&#xff0c;而 iOS 平台的 App Store 则是开发者们发布应用的主要渠道之一。因此&#xff0c;了解…...

Python入门【LEGB规则、面向对象简介、面向过程和面向对象思想、面向对象是什么? 对象的进化 、类的定义、对象完整内存结构 】(十三)

&#x1f44f;作者简介&#xff1a;大家好&#xff0c;我是爱敲代码的小王&#xff0c;CSDN博客博主,Python小白 &#x1f4d5;系列专栏&#xff1a;python入门到实战、Python爬虫开发、Python办公自动化、Python数据分析、Python前后端开发 &#x1f4e7;如果文章知识点有错误…...

【消息中间件】原生PHP对接Uni H5、APP、微信小程序实时通讯消息服务

文章目录 视频演示效果前言一、分析二、全局注入MQTT连接1.引入库2.写入全局连接代码 二、PHP环境建立总结 视频演示效果 【uniapp】实现买定离手小游戏 前言 Mqtt不同环境问题太多&#xff0c;新手可以看下 《【MQTT】Esp32数据上传采集&#xff1a;最新mqtt插件&#xff08;支…...

【C语言初阶】指针篇—上

目录 1. 指针是什么&#xff1f;2. 指针和指针类型2.1 指针-整数2.2 指针的解引用 3. 野指针3.1 野指针成因1. 指针未初始化2. 指针越界访问3. 指针指向的空间释放 3.2 如何规避野指针 1. 指针是什么&#xff1f; 指针是什么&#xff1f; 指针理解的2个要点&#xff1a; > 1…...

基于FasterRCNN深度学习网络的车辆检测算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 MATLAB2022A 3.部分核心程序 ....................................................................... % 训练Faster R-…...

机器学习深度学习——多层感知机

&#x1f468;‍&#x1f393;作者简介&#xff1a;一位即将上大四&#xff0c;正专攻机器学习的保研er &#x1f30c;上期文章&#xff1a;机器学习&&深度学习——感知机 &#x1f4da;订阅专栏&#xff1a;机器学习&&深度学习 希望文章对你们有所帮助 上一节…...

Django模型将模型注释同步到数据库

1、安装django-comment-migrate库 pip install django-comment-migrate 2、将库注册到settings.py文件中 INSTALLED_APPS [...django_comment_migrate, # 表注释... ] 3、加注释 3.1、给模型&#xff08;表&#xff09;加注释 在模型的class Meta中编辑 verbose_name&…...

STM32 Flash学习(二)

STM32F1的官方固件库操作FLASH的几个常用函数。这些函数和定义分布在源文件stm32f1xx_hal_flash.c/stm32f1xx_hal_flash_ex.c以及头文件stm32f1xx_hal_flash.h/stm32f1xx_hal_flash_ex.h中。 锁定解函数 对FLASH进行写操作前必须先解锁&#xff0c;解锁操作&#xff1a;在FLA…...

kotlin获取泛型集合的类型信息

通过 reified 关键字和内联函数来实现 inline fun <reified T> getClassFromList(list: List<T>): Class<T> {return T::class.java }fun main() {val list listOf("Hello", "World")val clazz getClassFromList(list)println(clazz)…...

AQS源码解析

关于 AQS&#xff0c;网上已经有无数的文章阐述 AQS 的使用及其源码&#xff0c;所以多这么一篇文章也没啥所谓&#xff0c;还能总结一下研究过的源码。源码解析和某某的使用&#xff0c;大概是互联网上 Java 文章中写得最多的主题了。 AQS AQS 是 AbstractQueuedSynchronize…...

关于在VS2017中编译Qt项目遇到的问题

关于在VS2017中编译Qt项目遇到的问题 【QT】VS打开QT项目运行不成功 error MSB6006 “cmd.exe”已退出,代码为 2。如何在VS2017里部署的Qt Designer上编辑槽函数 【QT】VS打开QT项目运行不成功 error MSB6006 “cmd.exe”已退出,代码为 2。 链接 如何在VS2017里部署的Qt Design…...

Python web实战 | 使用 Flask 实现 Web Socket 聊天室

概要 今天我们学习如何使用 Python 实现 Web Socket&#xff0c;并实现一个实时聊天室的功能。本文的技术栈包括 Python、Flask、Socket.IO 和 HTML/CSS/JavaScript。 什么是 Web Socket&#xff1f; Web Socket 是一种在单个 TCP 连接上进行全双工通信的协议。它是 HTML5 中的…...

别再手搓动画了!用PS搞定微信小程序GIF单次播放(附2022版安装包)

微信小程序GIF动画高效制作指南&#xff1a;从PS设计到开发落地全流程 在微信小程序开发中&#xff0c;动画效果的实现往往让开发者陷入两难选择&#xff1a;要么花费大量时间手写Canvas动画代码&#xff0c;要么寻找更高效的视觉呈现方案。当遇到需要精确控制播放次数的动画需…...

Navicat密码忘了别慌!手把手教你用Java小工具找回(支持15/16版本)

Navicat密码找回实战指南&#xff1a;零基础也能操作的Java解密方案 上周五凌晨两点&#xff0c;李工程师在部署紧急热修复时突然发现——Navicat里保存的生产数据库密码居然记不清了。这个场景对于经常需要管理多个数据库连接的开发者来说并不陌生。本文将详细介绍一套经过验证…...

Pocket Sync:Analogue Pocket玩家的终极游戏管理解决方案

Pocket Sync&#xff1a;Analogue Pocket玩家的终极游戏管理解决方案 【免费下载链接】pocket-sync A GUI tool (Mac, Windows, Linux) for doing stuff with the Analogue Pocket 项目地址: https://gitcode.com/gh_mirrors/po/pocket-sync 想象一下&#xff0c;你刚刚…...

Mainframer错误排查指南:常见问题及解决方法大全

Mainframer错误排查指南&#xff1a;常见问题及解决方法大全 【免费下载链接】mainframer Tool for remote builds. Sync project to remote machine, execute command, sync back. 项目地址: https://gitcode.com/gh_mirrors/ma/mainframer Mainframer是一款高效的远程…...

文字修仙项目市场价值与商业化分析

文字修仙 AI Agent&#xff1a;市场价值与个人开发者商业化实战指南 一、文字修仙游戏的市场基本面——小众赛道的大机会 1.1 全球文字/互动叙事游戏市场规模与增长 1.2 中文修仙品类的独特生态&#xff1a;QQ群 → 微信 → 抖音 1.3 用户画像&#xff1a;谁在玩文字修仙&…...

linuxcnc开发环境搭建

linux cnc &#xff0c;数控机床开源控制软件&#xff0c;实时系统。下载linuxcnc.iso镜像&#xff0c;在虚拟机里安装。安装成功运行起来。安装了amd64版本的qtcreator运行提示少libxcb&#xff1a;sudo apt update sudo apt install libxcb-cursor0打开窗口成功新建 一个工程…...

SVM实战调参指南:从标准化、核函数到支持向量解读

1. 这不是教科书里的SVM&#xff0c;而是我亲手调过37次参数后才敢写的入门实录Support Vector Machine&#xff08;SVM&#xff09;这个词&#xff0c;第一次见是在三年前的某次算法面试里。面试官问&#xff1a;“你说说SVM为什么叫‘支持向量’&#xff1f;”我张了张嘴&…...

脉冲神经网络SNN工程落地全链路指南:从LIF建模到边缘部署

1. 这不是又一本“神经网络入门”——它是一份面向真实研究与工程落地的脉冲神经网络实操手记“Spiking Neural Networks”&#xff08;SNN&#xff09;这个词&#xff0c;过去十年里在学术会议海报上出现的频率&#xff0c;几乎和咖啡渍在论文草稿边缘的扩散速度一样快。但如果…...

Unity SLG框架解析:Clash Engine六维系统架构与工程实践

1. 这不是“又一个SLG模板”&#xff0c;而是把“部落冲突”式玩法真正拆开揉碎的工程实践你有没有试过在Unity里搭一个像《部落冲突》那样的SLG&#xff1f;不是那种只有几个按钮、拖拽兵种就完事的Demo&#xff0c;而是真正能跑通资源采集→建筑升级→兵种训练→多线程战斗→…...

JWT密钥轮换缺陷与零停机热修复实战指南

1. 这不是一次普通升级&#xff0c;而是一次密钥信任体系的临界点崩塌Seedance2.0 v2.0.3发布不到72小时&#xff0c;我在给客户做例行安全巡检时&#xff0c;发现一个反直觉的现象&#xff1a;所有新签发的JWT令牌在旧版本客户端&#xff08;v2.0.2&#xff09;上验证失败&…...