Web 端顶级视效实现:山海鲸端渲染底层原理与发布模式详解
大家好,欢迎大家回到山海鲸的渲染模式系列教程。昨天,我们看了一下山海鲸支持的3种渲染模式的整体概览。今天,我们就来看一下山海鲸支持的最基础的渲染模式,也就是端渲染的渲染设置。
1. 山海鲸的端渲染
我们说到端渲染,再强调一下,山海鲸是可以在Web上达到顶级视效的渲染引擎。而且,我们可以不借助Pixel streaming实现这一效果。其底层原理在于,我们整个渲染系统都是自研的,基于WebGL编写。而大部分其他产品,它们使用的是游戏引擎,游戏引擎底层基于D3D,D3D的很多高级用法都不支持导出到WebGL,所以它们只能导出成Pixel streaming,无法直接在WebGL上进行端渲染。
2. 端渲染的三种模式
好,我们来看一下,山海鲸如果导出一个最基本的端渲染,有哪几种形式。我们前面也简单介绍了,山海鲸有两款软件:一款是编辑器,我们可以使用它进行编辑和移动操作;另一款是查看器,这是我们最终给客户部署的软件。我们也说过,编辑器也可以发布给自己使用。
2.1 直接在编辑器中发布一个网络链接
那我们先来看一下端渲染的第一种模式:直接在编辑器中发布一个网络链接。
这里我们已经发布了,我们先停止发布,重新走一下这个流程。我们点击发布,然后选择第一个Tab项“发布Web链接”。在“发布Web链接”里面,我们可以直接看到这些Web链接的基本设置。默认情况下,我们直接点“开始发布”就可以了。当然,我们也可以进行一些高级设置,比如自定义链接、登录、使用APP控制等。在基础设置里面,我们还可以把iframe嵌到我们自己的其他代码里面。当然,我们也可以去更改一些设置。
大家可以看到,我们点发布后打开链接,会有一个加载画面。如果大家需要替换这个加载画面,可以在项目OEM这边进行替换。我们点击项目OEM,就可以替换掉这些加载画面了。
好,这就是我们最基本的一种模式:在山海鲸中直接发布成一个Web链接。当然,我们这个示例使用了轻3D,我们先把轻3D关掉。上一节课我们设置了轻3D模式,按加载键选择后,我们先把它关闭成不生效,保存一下,再重新刷新一次。
好,这就是我们第一种模式了。我们可以看到,直接有一个加载画面,这个时候,我们就是一个端渲染的模式了。我们可以在Web浏览器中打开它。现在之所以卡,是因为我们开了两个画面,把这个画面关掉,就会稍微好一些。有的时候,GPU释放资源需要一定的时间。
在Web浏览器中,我们也可以直接点全屏,所以这个也可以直接在大屏上进行播放。
好,我们刚刚看到了,我们改了一下轻3D设置,然后这边直接更新了。这就是我们发布成Web链接的属性设置,我们可以更新同步,也就是直接实时更新,一保存项目就自动更新。还有一种方式是手动更新,也就是说我们上线需要一个流程。点了手动更新之后,我们更新一下。
好,这时候假设我要改变一下建筑的位置,改变之后我们保存好,可以看到这时候只显示保存成功,它并不会去改变我们线上发布项目的位置。我们可以把它离得远一点,它也不会去改变我们线上发布项目的位置。我们刷新一下,因为我们现在还是在渲染两个项目,肯定会略微有些卡。可以看到这个位置还是在这里的,为什么呢?因为我们现在选择的是手动更新,我们需要主动去点一下更新。
这样子,我们就很好区隔了编辑环境和线上环境。如果我们希望简单先编辑,现在临时存个草稿,就不要去点更新就行了。
好,这是我们第一种端渲染的发布模式:直接用编辑器发布。
2.2 发布到查看器中去
第二种,我们前面说了,可以发布到查看器中去。我们查看器也是点击发布,然后点击“导出部署文件”。注意这里,我们需要填一个项目码。项目码在哪里找到呢?我们先在我们客户的电脑上安装一个山海鲸查看器,安装完了之后,这里会有个项目码。因为我们有两个项目,这两个项目分别使用的是这两个项目码。那我们现在一个新的项目的话,就会显示一个新的项目码,我们就把这个项目码复制一下。当然,我们这两个项目都很类似,那没关系,我们再部署一次。我们点击这个项目码之后,点“开始导出”。
当然,我们这边有个部署方式,部署方式是有不同的,这也都是方便我们去给客户部署的时候,使用不一样的情况。比如说,我们有时候给客户部署,但是客户不是最终交付,那你可以设置个项目的失效时间。我们这里就以最终部署方式去走。
好,我们点击导出,它会先去计算一下整个项目的一个内容,然后最终把它导出出来。导出出来之后,我们这个项目就和这个项目码进行绑定了。我们到查看器中,就可以导入这个项目码。好,我们先在这里,因为我们前面已经有了,我们就把这个标注为一个“新”。好,然后我们在这边去导入它。导入成功之后它会自动打开,打开之后,我们有两种选择:
第一个选择就是我们所谓的CS模式,也就是说我们现在在这样的一个查看器中打开,我们可以直接点全屏,那这样,我们就已经在这台电脑上进行部署了,然后就直接播放了。
2.3 通过查看器发布成Web链接
当然,我们也可以关掉它,然后我们可以看到,它已经自动帮我们发布了。我们也可以打开这个链接,当然,我们前面说了,云渲染后面也是可以通过这个链接打开的,但这里我们不支持云渲染,是因为我们刚刚是没有去勾选云渲染的这个选项的,所以这里是不支持打开的。
3. 总结
可以看到,好,所以这就是端渲染的三种模式:一种是在编辑器中直接发布;另外一种呢,是我们导到查看器中,用软件的方式打开;第三种呢,是我们通过查看器发布成Web链接。一共三种模式。
好,今天我们学习端渲染的设置就到这里,谢谢大家。
相关文章:
Web 端顶级视效实现:山海鲸端渲染底层原理与发布模式详解
大家好,欢迎大家回到山海鲸的渲染模式系列教程。昨天,我们看了一下山海鲸支持的3种渲染模式的整体概览。今天,我们就来看一下山海鲸支持的最基础的渲染模式,也就是端渲染的渲染设置。 1. 山海鲸的端渲染 我们说到端渲染…...

腾讯云国际站性能调优
全球化业务扩张中,云端性能直接决定用户体验与商业成败。腾讯云国际站通过资源适配、网络优化与存储革新,为企业提供全链路调优方案。 资源精准适配 实例选型需与业务场景深度耦合,计算优化型实例加速AI训练效率3倍,内存…...

深入解析操作系统内核与用户空间以及内核态与用户态转换
用户空间和内核空间的划分是现代操作系统的基础,对应用程序网络模型的设计和优化有着深远的影响。 内核空间与用户空间的分工 现代操作系统为了保证系统的稳定性和安全性,将虚拟内存空间划分为用户空间和内核空间。 一、用户空间 用户空间是用户程序…...

每日一题洛谷P8662 [蓝桥杯 2018 省 AB] 全球变暖c++
P8662 [蓝桥杯 2018 省 AB] 全球变暖 - 洛谷 (luogu.com.cn) DFS #include<iostream> using namespace std; int n, res; char a[1005][1005]; bool vis[1005][1005]; bool flag; int dx[4] { 0,0,1,-1 }; int dy[4] { 1,-1,0,0 }; void dfs(int x, int y) {vis[x][y]…...

【JVM】初识JVM 从字节码文件到类的生命周期
初识JVM JVM(Java Virtual Machine)即 Java 虚拟机,是 Java 技术的核心组件之一。JVM的本质就是运行在计算机上的一个程序,通过软件模拟实现了一台抽象的计算机的功能。JVM是Java程序的运行环境,负责加载字节码文件&a…...

多级体验体系构建:基于开源AI智能客服与AI智能名片的S2B2C商城小程序体验升级路径研究
摘要:在体验经济时代,传统企业单一的总部体验模式难以覆盖全链路用户需求。本文针对B端与C端体验深度差异,提出“一级总部体验—二级区域体验—三级终端体验”的分层架构,并引入“开源AI智能客服”与“AI智能名片”技术࿰…...
每日算法 -【Swift 算法】字符串转整数算法题详解:myAtoi 实现与正则表达式对比
Swift 字符串转整数算法题详解:myAtoi 实现与正则表达式对比 🧩 题目背景 LeetCode 上的经典算法题 8. String to Integer (atoi) 是一道考察字符串解析与边界处理的题目。这道题虽看似简单,但处理细节相当复杂。我们将使用 Swift 语言实现…...
记录一个难崩的bug
1.后端配置了 Filter 过滤器,如果再配置了Configuration ,那么会出现冲突吗? 过滤器与Configuration类本身无直接冲突,但需注意注册机制、执行顺序和依赖管理。通过显式控制过滤器的注册方式和优先级,结合Spring Security的链式配…...

Git切换历史版本及Gitee云绑定
1、git介绍 Git是目前世界上最先进的分布式版本控制系统 Linux <- BitKeeper(不是开源的,但免费的,后来要收费) Linus Torvalds(林纳斯托瓦兹) 两周时间吧,弄了个 Git;大约一个月就把Linux代码从BitK…...
智能外呼系统中 NLP 意图理解的工作原理与技术实现
智能外呼系统通过整合语音识别(ASR)、自然语言处理(NLP)和语音合成(TTS)等技术,实现了自动化的电话交互。其中,NLP 意图理解是核心模块,负责解析用户话语中的语义和意图&…...

服务器的IP是什么东西?
一、什么是服务器的IP地址? 服务器的IP地址是互联网协议(Internet Protocol)的缩写,是服务器在网络中的唯一数字标识符。它类似于现实生活中的门牌号,用于标识服务器在网络中的位置,使其他设备能够通过它与…...

[问题解决]:Unable to find image ‘containrrr/watchtower:latest‘ locally
一,问题 在使用docker安装部署新应用的时候,报错:Unable to find image containrrr/watchtower:latest locally 分析认为是当前docker的资源库里找不到这个软件的镜像,需要配置一个包含这个软件镜像的新的资源库。 二࿰…...

【文件上传】阿里云对象存储服务实现文件上传
一、基础 上传到本地: package org.example.controller;import lombok.extern.slf4j.Slf4j; import org.example.pojo.Result; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; imp…...

IPv6代理如何引领下一代网络未来
随着互联网技术的不断发展,IPv6逐渐成为下一代网络协议的核心,替代IPv4已是大势所趋。IPv6代理作为IPv6网络环境下的重要工具,为用户提供了更高效、更安全的网络解决方案。 IPv6代理的定义 IPv6代理是在IPv6网络环境中为处理IPv4转换和其他网…...

Linux——数据链路层
1. 认识以太网 认知:以太网是用于局域网数据通信的协议标准,定义了同一局域网内通过电缆/无线怎么在设备之间传输数据帧。 注:整个网络世界可以具象看出由许许多多的局域网组成, • 家庭中的设备A and 家庭中的设备B and 家庭路由…...
ubuntu 22.04 安装下载
ubuntu 22.04下载安装及相关配置_ubuntu22.04下载-CSDN博客...
深度学习面试八股简略速览
在准备深度学习面试时,你可能会感到有些不知所措。毕竟,深度学习是一个庞大且不断发展的领域,涉及众多复杂的技术和概念。但别担心,本文将为你提供一份全面的指南,从基础理论到实际应用,帮助你在面试中脱颖…...
【深度学习-pytorch篇】1. Pytorch矩阵操作与DataSet创建
Pytorch矩阵操作与DataSet创建 1. Python 环境配置 1.1 安装 Anaconda 推荐使用 Anaconda 来管理 Python 环境,访问官网下载安装: https://www.anaconda.com/download/success 1.2 安装 PyTorch 请根据自己的系统平台(Windows/Linux/ma…...

游戏引擎学习第310天:利用网格划分完成排序加速优化
回顾并为今天的内容做个铺垫 昨天我们完成了一个用于排序的空间划分系统,但还没有机会真正利用它。昨天的工作刚好在结束时才完成,所以今天我们打算正式使用这个空间划分来加速排序。 现在我们在渲染代码中,可以看到在代码底部隐藏着一个“…...

数据结构 - 树的遍历
一、二叉树的遍历 对于二叉树,常用的遍历方式包括:先序遍历、中序遍历、后序遍历和层次遍历 。 1、先序遍历(PreOrder) 先序遍历的操作过程如下: 若二叉树为空,则什么也不做;否则࿰…...

时序模型介绍
一.整体介绍 1.单变量 vs 多变量时序数据 单变量就是只根据时间预测,多变量还要考虑用户 2.为什么不能用机器学习预测: a.时间不是影响标签的关键因素 b.时间与标签之间的联系过于弱/过于复杂,因此时序模型依赖于时间与时间的相关性来进行预…...
Java面试实战:从Spring到大数据的全栈挑战
Java面试实战:从Spring到大数据的全栈挑战 在某家知名互联网大厂,严肃的面试官正在面试一位名叫谢飞机的程序员。谢飞机以其搞笑的回答和对Java技术栈的独特见解而闻名。 第一轮:Spring与微服务的探索 面试官:“请你谈谈Spring…...
解决idea与springboot版本问题
遇到以下问题: 1、springboot3.2.0与jdk1.8 提示这个包org.springframework.web.bind.annotation不存在,但是pom已经引入了spring-boot-starter-web 2、Error:Cannot determine path to tools.jar library for 17 (D:/jdk17) 3、Error:(3, 28) java: …...

【第4章 图像与视频】4.4 离屏 canvas
文章目录 前言为什么要使用 offscreenCanvas为什么要使用 OffscreenCanvas如何使用 OffscreenCanvas第一种使用方式第二种使用方式 计算时长超过多长时间适合用Web Worker 前言 在 Canvas 开发中,我们经常需要处理复杂的图形和动画,这些操作可能会影响页…...
[AXI]如何验证AXI5原子操作
如何验证 AXI5 原子操作 摘要:在 UVM (Universal Verification Methodology) 验证环境中,验证 AXI5 协议的原子操作 (Atomic Operations) 是一项重要的任务,特别是在验证支持高并发和数据一致性的 SoC (System on Chip) 设计时。AXI5 引入了原…...

尚硅谷redis7 74-85 redis集群分片之集群是什么
74 redis集群分片之集群是什么 如果主机宕机,那么写操作就被暂时中断,后面就要由哨兵进行投票和选举。那么一瞬间若有大量的数据修改,由于写操作中断就会导致数据流失。 由于数据量过大,单个Master复制集难以承担,因此需要对多个复制集进行…...
Android获取设备信息
使用java: List<TableMessage> dataListnew ArrayList<TableMessage>();//获取设备信息Hashtable<String,String> ht MyDeviceInfo.getDeviceAllInfo2(LoginActivity.this);for (Map.Entry<String, String> entry : ht.entrySet()) {String key entry…...

WPF的基础控件:布局控件(StackPanel DockPanel)
布局控件(StackPanel & DockPanel) 1 StackPanel的Orientation属性2 DockPanel的LastChildFill3 嵌套布局示例4 性能优化建议5 常见问题排查 在WPF开发中,布局控件是构建用户界面的基石。StackPanel和DockPanel作为两种最基础的布局容器&…...

apache的commons-pool2原理与使用详解
Apache Commons Pool2 是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能。 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击…...

打印Yolo预训练模型的所有类别及对应的id
有时候我们可能只需要用yolo模型检测个别类别,并显示,这就需要知道id,以下代码可打印出 from ultralytics import YOLO# 加载模型 model YOLO(yolo11x.pt)# 打印所有类别名称及其对应的ID print(model.names) {0: person, 1: bicycle, 2: c…...