福州市交通建设集团有限公司网站上海新建公司

bicheng/2026/1/26 19:21:11/文章来源:
福州市交通建设集团有限公司网站,上海新建公司,网站设计深圳哪家强?,网站搭建实训总结如果弹幕内容只支持文字的话#xff0c;只需要借助 canvas 绘图上下文的 fillText 方法就可以实现功能了。 但如果想同时支持渲染图片和文字的话#xff0c;需要以下几个步骤#xff1a; 设计一个面向用户的数据结构#xff0c;用于描述弹幕应该渲染哪些文字和图片#x…如果弹幕内容只支持文字的话只需要借助 canvas 绘图上下文的 fillText 方法就可以实现功能了。 但如果想同时支持渲染图片和文字的话需要以下几个步骤 设计一个面向用户的数据结构用于描述弹幕应该渲染哪些文字和图片框架内部对上述数据结构进行解析解析出文字部分和图片部分计算出各个部分相对于弹幕整体左上角的 top 偏移量和 left 偏移量弹幕渲染时首先计算出弹幕整体左上角距离 canvas 原点的 top 和 left这块的计算是后续的内容后续再说然后再根据弹幕整体的 top 和 left 结合各个部分的 top、left 偏移量循环渲染各个部分。 整体逻辑如下图所示 相关 API 可以看官网的这里https://fly-barrage.netlify.app/guide/barrage-image.html 下面着重说说上面几点具体是如何实现的。 1面向用户的数据结构用于描述弹幕应该渲染哪些文字和图片 设计的数据结构如下所示 export type BaseBarrageOptions {// 弹幕的内容eg文本内容[图片id]文本内容[图片id]文本内容text: string; }例如“[0001]新年快乐[0003]”它的渲染效果就是如下这样子的。 2对上述结构进行解析解析出文字以及图片部分 这块对应源码中的 class BaseBarrage -- analyseText 方法源码如下所示 /*** 弹幕类*/ export default abstract class BaseBarrage {/*** 解析 text 内容* 文本内容[图片id]文本内容[图片id] [文本内容, [图片id], 文本内容, [图片id]]* param barrageText 弹幕文本*/analyseText(barrageText: string): Segment[] {const segments: Segment[] [];// 字符串解析器while (barrageText) {// 尝试获取 ]const rightIndex barrageText.indexOf(]);if (rightIndex ! -1) {// 能找到 ]尝试获取 rightIndex 前面的 [const leftIndex barrageText.lastIndexOf([, rightIndex);if (leftIndex ! -1) {// [ 能找到if (leftIndex ! 0) {// 如果不等于 0 的话说明前面是 textsegments.push({type: text,value: barrageText.slice(0, leftIndex),})}segments.push({type: rightIndex - leftIndex 1 ? image : text,value: barrageText.slice(leftIndex, rightIndex 1),});barrageText barrageText.slice(rightIndex 1);} else {// [ 找不到segments.push({type: text,value: barrageText.slice(0, rightIndex 1),})barrageText barrageText.slice(rightIndex 1);}} else {// 不能找到 ]segments.push({type: text,value: barrageText,});barrageText ;}}// 相邻为 text 类型的需要进行合并const finalSegments: Segment[] [];let currentText ;for (let i 0; i segments.length; i) {if (segments[i].type text) {currentText segments[i].value;} else {if (currentText ! ) {finalSegments.push({ type: text, value: currentText });currentText ;}finalSegments.push(segments[i]);}}if (currentText ! ) {finalSegments.push({ type: text, value: currentText });}return finalSegments;} }/*** 解析完成的片段*/ export type Segment {type: text | image,value: string }analyseText 方法的作用就是将 “[0001]新年快乐[0003]” 解析成如下数据 [{type: image,value: [0001]},{type: text,value: 新年快乐},{type: image,value: [0003]}, ]这块的核心逻辑是字符串解析器这里我借鉴了 Vue2 模板编译中解析器的实现Vue 解析器的解析可以看我的这篇博客https://blog.csdn.net/f18855666661/article/details/118422414。 这里我使用 while 不断的循环解析 barrageText 字符串一旦解析出一块内容便将其从 barrageText 字符串中裁剪出去并且将对应的数据 push 到 segments 数组中当 barrageText 变成一个空字符串的时候整个字符串的解析也就完成了。 具体的解析过程大家看我的注释即可很容易理解。 3计算出各个部分相对于弹幕整体左上角的 top 偏移量和 left 偏移量 这块对应源码中的 class BaseBarrage -- initBarrage 方法源码如下所示 /*** 弹幕类*/ export default abstract class BaseBarrage {/*** 进行当前弹幕相关数据的计算*/initBarrage() {const sectionObjects this.analyseText(this.text);let barrageImage;// 整个弹幕的宽let totalWidth 0;// 整个弹幕的高let maxHeight 0;// 计算转换成 sectionsconst sections: Section[] [];sectionObjects.forEach(sectionObject {// 判断是文本片段还是图片片段if (sectionObject.type image (barrageImage this.br.barrageImages?.find(bi [${bi.id}] sectionObject.value))) {totalWidth barrageImage.width;maxHeight maxHeight barrageImage.height ? barrageImage.height : maxHeight;// 构建图片片段sections.push(new ImageSection({...barrageImage,leftOffset: Utils.Math.sum(sections.map(section section.width)),}));} else {// 设置好文本状态后进行文本的测量this.setCtxFont(this.br.ctx);const textWidth this.br.ctx?.measureText(sectionObject.value).width || 0;const textHeight this.fontSize * this.lineHeight;totalWidth textWidth;maxHeight maxHeight textHeight ? textHeight : maxHeight;// 构建文本片段sections.push(new TextSection({text: sectionObject.value,width: textWidth,height: textHeight,leftOffset: Utils.Math.sum(sections.map(section section.width)),}));}})this.sections sections;// 设置当前弹幕的宽高如果自定义中定义了的话则取自定义中的 width 和 height因为弹幕实际呈现出来的 width 和 height 是由渲染方式决定的this.width this.customRender?.width ?? totalWidth;this.height this.customRender?.height ?? maxHeight;// 遍历计算各个 section 的 topOffsetthis.sections.forEach(item {if (item.sectionType text) {item.topOffset (this.height - this.fontSize) / 2;} else {item.topOffset (this.height - item.height) / 2;}});} }initBarrage 首先调用 analyseText 方法实现弹幕字符串的解析工作然后对 analyseText 方法的返回值进行遍历处理。 在遍历的过程中首先判断当前遍历的片段是文本片段还是图片片段当片段的 type 是 image 并且对应的图片 id 已有对应配置的话则表明当前是图片片段否则就是文本片段。 然后需要根据片段的类型去计算对应片段的宽和高图片类型的宽高不用计算因为图片的尺寸是用户通过 API 传递进框架的框架内部直接取就可以了。文本片段的宽使用渲染上下文的 measureText 方法可以计算出文本片段的高等于弹幕的字号乘以行高。 各个片段的宽高计算出来之后开始计算各个片段的 left 偏移量由于每个计算好的片段都会被 push 到 sections 数组中所以当前片段的 left 偏移量等于 sections 数组中已有片段的宽度总和。 top 偏移量需要知道弹幕整体的高度弹幕整体的高度等于最高片段的高度所以在循环处理 sectionObjects 的过程中使用 maxHeight 变量判断记录最高片段的高度在 sectionObjects 循环结束之后就可以计算各个片段的 top 偏移量了各个片段的 top 偏移量等于弹幕整体高度减去当前片段实际渲染高度然后除以 2。 4弹幕渲染时的操作 弹幕渲染时首先需要计算出弹幕整体左上角的定位这个是后面的内容之后再说这里先假设某个弹幕渲染时整体左上角的定位是10px10px各个片段的 top、left 偏移量已经计算出来了结合这两块数据可以计算出各个片段左上角的定位。至此循环渲染出各个片段即可完成整体弹幕的渲染操作相关源码如下所示 /*** 弹幕类*/ export default abstract class BaseBarrage {// 用于描述渲染时弹幕整体的 top 和 lefttop!: number;left!: number;/*** 将当前弹幕渲染到指定的上下文* param ctx 渲染上下文*/render(ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {// 设置绘图上下文this.setCtxFont(ctx);ctx.fillStyle this.color;// 遍历当前弹幕的 sectionsthis.sections.forEach(section {if (section.sectionType text) {ctx.fillText(section.text, this.left section.leftOffset, this.top section.topOffset);} else if (section.sectionType image) {ctx.drawImage(Utils.Cache.imageElementFactory(section.url),this.left section.leftOffset,this.top section.topOffset,section.width,section.height,)}})} }5总结 ok以上就是弹幕内容支持混入渲染图片的设计与实现后面说说各种类型弹幕的具体设计。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/86440.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网站建设与应用岗位wordpress中文版

文章目录 前言2D官方游戏案例资源下载项目配置添加角色节点模拟运行移动根节点 结束 Godot专栏地址 前言 Godot 官方给了我们2D游戏和3D游戏的案例,不过如果是独立开发者只用考虑2D游戏就可以了,因为2D游戏纯粹,我们只需要关注游戏的玩法即可…

德州网站开发人员宝格丽官网

在敏捷开发的 SCRUM 流程中, 一个基本要求就是团队中的成员在每日例会中介绍自己昨天的进度, 今天的计划, 和遇到的困难。 下面是《现代软件工程》课程上一个学生团队在2/18 和 2/19 这两天的报告。 粗粗看去, 不禁有 “昨日重来” 的感觉。 一些同学的任务在2/18 报告的 yest…

一般的网站方案建设书模板做建网站的公司

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 cv::detail::computeImageFeatures 是 OpenCV 中用于计算一组图像的特征点和描述符的函数,通常在图像拼接或类似的任务中使用。这个函…

合肥企业网站排名优化ppt模板免费下载整套

好处,未来 很清楚展示GPT插件的调用过程: 把请求和要求发chatGPT chatGPT返回markdown格式发给插件 插件返回结果给用户。 你不用别人用。 人工智能(AI)的最危险之处通常与以下几个方面有关: 自主决策能力过强&…

长沙做网站推广wordpress协会主题

大白话javascript实现一个函数,将字符串中的指定子串全部替换为另一个字符串的原理,以及多种方法实现。 在JavaScript里,要是你想把字符串里的指定子串都替换成另外一个字符串,有不少方法可以实现。下面我会详细介绍实现的原理&a…

中国建设银行网站官网网址120亿营收超120亿

问题复盘 1.TCP和UDP的区别;网络中七层协议详细解释 2.cookie和session的区别——python中request的用法 3.cookie和session的生命周期 cookie的生命周期: 持久性cookie:如果创建时指定了过期时间(‘Expires’属性&#xff0…

我找客户做网站怎么说网站关键字优化软件

基础原理 由于对碗口进行缺口检测,因此只需要碗口的边界信息。得到陶瓷碗区域填充后的图像,对图像进行边缘检测。这是属于图像分割中的内容,在图像的边缘中,可以利用导数算子对数字图像求差分,将边缘提取出来。 案例…

档案网站建设文献综述大连网站哪家做的好?

文章目录 1. SCA的重要性2. SCA的工作方式3. 安全漏洞分析4. 许可证合规性5. 代码质量和维护性结语 在当今的快速发展的软件行业中,软件成分分析(Software Composition Analysis,简称SCA)已成为一个不可或缺的工具。SCA的主要任务…

邢台网站建设制作山西旅游网站建设

一.题目描述 有一个3*4的矩阵,要求求出其中最大值的那个元素的值,以及其所在的行号和列号 比如:给定一个3*4的矩阵如下 输出结果:最大值为 12 ,行号为3, 列号为2 二.思路分析 打擂台算法: 先思考…

网站做有偿广告需要什么有序如何运用企业官方网站做宣传

采样次数(Sampling Points) 在给定时间内记录信号值的次数。 假设在1秒内对一个连续信号采样10次,这意味着每0.1秒记录一次信号值。 假设在1秒内对一个连续信号采样100次,这意味着每0.01秒记录一次信号值。 频率(Fre…

平度168网站建设高端网站建设团队

以TFRecord方式存储的优点 高效性:TFRecord是一种二进制格式,可以提供更高的存储和读取效率。它可以更快地读取和解析数据,特别适用于大规模数据集 可压缩性:TFRecord可以使用压缩算法进行压缩,减小数据文件的大小。这…

东莞企业网站找谁wordpress 个人站

1 实验目的 掌握SQL视图语句的基本使用方法,如CREATE VIEW、DROP VIEW。掌握视图更新、WITH CHECK OPTION等高级功能的使用。 2 实验内容 2.1 掌握SQL视图语句的基本使用方法 创建视图(省略视图列名)。创建视图(不能省略列名的…

阜阳建设网站公司电话网站建设难做吗

使用命令 gcc -v -E -x c - 看自己gcc 有没有安装好 也可以在自己的vscode中新建一个终端 gcc -v g -v 首先把自己的C51 和MDK 路径 设置好 vscode 中设置 C51 和 MDK 的路径 这是你keil 中写 51单片机和 STM32 的 如果你出现什么include 的什么波浪线,那估计…

免费海报设计网站有哪些如何选择家居网站建设

Stable Diffusion是一个深度学习模型,专注于生成高质量的图像。它由CompVis团队与Stability AI合作开发,并在2022年公开发布。这个模型使用文本提示(text prompts)生成详细、逼真的图像,是目前人工智能图像生成领域的一…

做品牌形象网站推广平台哪个好

前言 本文介绍使用4D毫米波雷达,实现目标检测与可行驶区域分割,它是来自CVPR2022的。 会讲解论文整体思路、输入数据分析、模型框架、设计理念、损失函数等,还有结合代码进行分析。 论文地址:Raw High-Definition Radar for Mu…

网站域名想更换要怎么做施工企业排名

第1章: 第2章: 第3章: 第4章: 第5章: 第6章: 第7章: 第8章: 第9章:

网页给别人做的 网站后续收费吗WordPress评论列表去掉回复

由麦克斯韦方程组推出均匀平面电磁波及其特征 均匀平面电磁波是指在传输方向垂直与传输方向垂直的平面上,电磁波的每一点的电场和磁场都相同,这种电磁波被称作均匀平面电磁波。 研究任何一种物理现象,当一种物理现象特别复杂的时候&#xf…

南宁手机做网站设计高端网站建设 n磐石网络

理解递归 一、递归的特征 1.执行范围不断缩小 递归类似数学里的递推,设计递归就是努力寻找数学里的递推公式,例如阶乘的递推公式就是f()n*f(n-1),很明显一定是要触底之后才能反弹。再比如斐波那契数列的递归公式为f(n)f(n-1)f(n-2),n也在不断缩小。这条…

在国外网站建设班级网站自助建设功能

文章目录 CVE-2023-3836:大华智慧园区综合管理平台任意文件上传漏洞复现0x01 前言0x02 漏洞描述0x03 影响范围0x04 漏洞环境0x05 漏洞复现1.访问漏洞环境2.构造POC3.复现 CVE-2023-3836:大华智慧园区综合管理平台任意文件上传漏洞复现 0x01 前言 免责声…

中国联通网站备案管理系统个人网页介绍

文章目录 文件指针概述文件指针打开模式文件常用操作函数fprintf()函数fscanf()函数fgets()函数fputc()函数fgetc()函数feek()函数fre…