鸿蒙(API 12 Beta6版)图形加速【OpenGL ES平台内插模式】超帧功能开发

server/2024/11/13 9:14:40/

超帧内插模式是利用相邻两个真实渲染帧进行超帧计算生成中间的预测帧,即利用第N-1帧和第N帧真实渲染帧预测第N-0.5帧预测帧,如下图所示。由于中间预测帧的像素点通常能在前后两帧中找到对应位置,因此内插模式的预测帧效果较外插模式更优。由于第N帧真实渲染帧需要等待第N-0.5帧预测帧生成并送显后才能最终送显,因此会新增1~2帧的响应时延。

1

OpenGL ES平台

业务流程

基于OpenGL ES图形API平台,集成超帧内插模式的主要业务流程如下:

2

  1. 用户进入超帧适用的游戏场景。
  2. 游戏应用调用[HMS_FG_CreateContext_GLES]接口创建超帧上下文实例。
  3. 游戏应用调用接口配置超帧实例属性。包括调用[HMS_FG_SetAlgorithmMode_GLES](必选)设置超帧算法模式并选择内插模式;调用[HMS_FG_SetResolution_GLES](必选)设置超帧输入输出图像分辨率;调用[HMS_FG_SetCvvZSemantic_GLES](可选)设置齐次裁剪空间Z/W范围及深度测试函数;调用[HMS_FG_SetImageFormat_GLES](可选)设置真实渲染帧颜色缓冲区图像格式;如果颜色缓冲区相对深度模板缓冲区基于y轴翻转180度,则调用[HMS_FG_SetDepthStencilYDirectionInverted_GLES](可选)设置翻转状态。
  4. 游戏应用调用[HMS_FG_Activate_GLES]接口激活超帧上下文实例。
  5. 游戏应用调用[HMS_FG_Dispatch_GLES]接口并传入历史真实渲染帧颜色信息、深度信息、相机矩阵信息,生成预测帧,并更新预测帧缓冲区。当相机视图投影矩阵的平移分量非常大时(如超过10W),预测帧效果下降,画面易出现闪烁。此时可在[HMS_FG_Dispatch_GLES]接口调用前调用[HMS_FG_SetExtendedCameraInfo_GLES]设置相机扩展信息,从而获取精度更高的预测帧效果。
  6. 预测帧绘制UI并送显。
  7. 绘制缓存中的上一帧真实渲染帧,并绘制UI。
  8. 上一帧真实渲染帧送显。
  9. 渲染游戏场景获取真实渲染帧,缓存真实渲染帧颜色信息、深度信息、相机矩阵等信息,用于后续超帧预测。由于内插模式真实帧需要等待前一帧预测帧绘制并送显后再送显,因此此处缓存一帧真实帧信息。跳转至序号5继续执行,直到退出游戏场景。
  10. 用户退出超帧适用的游戏场景。
  11. 游戏应用调用[HMS_FG_DestroyContext_GLES]接口销毁超帧上下文实例并释放内存资源。

开发步骤

本节阐述基于OpenGL ES图形API平台的超帧调用示例。

  1. 引用Graphics Accelerate Kit超帧头文件:frame_generation_gles.h。
// 引用超帧frame_generation_gles.h头文件
#include <graphics_game_sdk/frame_generation_gles.h>
  1. 编写CMakeLists.txt。
find_library(# Sets the name of the path variable.framegeneration-lib# Specifies the name of the NDK library that you want CMake to locate.libframegeneration.so
)target_link_libraries(entry PUBLIC${framegeneration-lib}
)
  1. 调用[HMS_FG_CreateContext_GLES]接口创建超帧上下文实例。
// 创建超帧上下文实例
FG_Context_GLES* context_ = HMS_FG_CreateContext_GLES();
if (context_ == nullptr) {return false;
}
  1. 调用超帧实例属性配置接口,超帧算法模式选择内插模式。

    // 初始化超帧接口调用错误码FG_ErrorCode errorCode = FG_SUCCESS;
    // 超帧算法模式FG_AlgorithmModeInfo aInfo{};aInfo.predictionMode = FG_PREDICTION_MODE_INTERPOLATION;                  // 内插模式aInfo.meMode = FG_ME_MODE_BASIC;                                          // 运动估计基础模式errorCode = HMS_FG_SetAlgorithmMode_GLES(context_, &aInfo);               // [必选] 设置超帧算法模式if (errorCode != FG_SUCCESS) {    return false;}
    // 真实帧颜色缓冲区分辨率FG_Dimension2D inputColorResolution{};                                    inputColorResolution.width = 1280;                                        // 真实帧颜色缓冲区图像宽度inputColorResolution.height = 720;                                        // 真实帧颜色缓冲区图像高度// 真实帧深度模板缓冲区分辨率FG_Dimension2D inputDepthStencilResolution{};                             inputDepthStencilResolution.width = 1280;                                 // 真实帧深度模板缓冲区图像宽度inputDepthStencilResolution.height = 720;                                 // 真实帧深度模板缓冲区图像高度// 预测帧分辨率FG_Dimension2D outputColorResolution{};                                    outputColorResolution.width = 1280;                                       // 预测帧图像宽度outputColorResolution.height = 720;                                       // 预测帧图像高度// 超帧输入输出图像分辨率FG_ResolutionInfo rInfo{};rInfo.inputColorResolution = inputColorResolution;rInfo.inputDepthStencilResolution = inputDepthStencilResolution;rInfo.outputColorResolution = outputColorResolution;errorCode = HMS_FG_SetResolution_GLES(context_, &rInfo);                  // [必选] 设置超帧输入输出图像分辨率if (errorCode != FG_SUCCESS) {    return false;}
    // [可选] 设置齐次裁剪空间Z/W范围及深度测试模式,接口不调用时默认为FG_CVV_Z_SEMANTIC_MINUS_ONE_TO_ONE_FORWARD_ZerrorCode = HMS_FG_SetCvvZSemantic_GLES(context_, FG_CVV_Z_SEMANTIC_MINUS_ONE_TO_ONE_FORWARD_Z);if (errorCode != FG_SUCCESS) {    return false;}
    // [可选] 设置真实渲染帧颜色缓冲区图像格式,接口不调用时默认为FG_FORMAT_R8G8B8A8_UNORMerrorCode = HMS_FG_SetImageFormat_GLES(context_, FG_FORMAT_R8G8B8A8_UNORM);if (errorCode != FG_SUCCESS) {    return false;}
    // [可选] 当颜色缓冲区相对深度模板缓冲区基于y轴翻转180度时,设置第二个参数为true,接口不调用时默认为falseerrorCode = HMS_FG_SetDepthStencilYDirectionInverted_GLES(context_, true);if (errorCode != FG_SUCCESS) {    return false;}
    
  2. 调用[HMS_FG_Activate_GLES]接口激活超帧上下文实例。

// 激活超帧上下文实例
errorCode = HMS_FG_Activate_GLES(context_);
if (errorCode != FG_SUCCESS) {return false;
}
  1. 游戏运行中,真实帧和预测帧交替渲染并送显。渲染真实帧时,缓存颜色信息、深度信息和相机矩阵等属性信息。渲染预测帧时,需调用[HMS_FG_Dispatch_GLES]接口并传入上一帧真实帧属性信息,指定预测帧缓冲区索引,生成预测帧,最终更新预测帧缓冲区内存。
// 帧计数
uint32_t frameNum = 0;
// 帧生成属性配置结构体
FG_DispatchDescription_GLES dispatchDescriptionData_ {.inputColor = 0U, .inputDepthStencil = 0U, .viewProj{}, .invViewProj{}, .outputColor = 0U
};// 变量声明
uint32_t inputColor = 0;
uint32_t inputDepthStencil = 0;
uint32_t outputColor = 0;
FG_Mat4x4 preViewProj;
FG_Mat4x4 preInvViewProj;// 帧循环
while (true) {frameNum += 1;if ((frameNum & 1) != 0) { // 预测帧渲染阶段    // 传入上一帧真实渲染帧颜色缓冲区索引dispatchDescriptionData_.inputColor = inputColor;// 传入上一帧真实渲染帧深度模板缓冲区索引dispatchDescriptionData_.inputDepthStencil = inputDepthStencil;// 传入预测帧缓冲区索引dispatchDescriptionData_.outputColor = outputColor;// 传入上一帧真实渲染帧视图投影矩阵dispatchDescriptionData_.viewProj = preViewProj;// 传入上一帧真实渲染帧视图投影逆矩阵dispatchDescriptionData_.invViewProj= preInvViewProj;// [可选] 当视图投影矩阵的平移分量非常大时,可提供相机扩展属性信息获得更加准确的超帧效果FG_PerFrameExtendedCameraInfo info;errorCode = HMS_FG_SetExtendedCameraInfo_GLES(context_, &info);// 生成预测帧,更新预测帧缓冲区的内存errorCode = HMS_FG_Dispatch_GLES(context_, &dispatchDescriptionData_);switch (errorCode) {case FG_SUCCESS: { // 生成预测帧成功// 绘制预测帧// ...// 绘制UI// ...// 预测帧送显// ...break;}case FG_COLLECTING_PREVIOUS_FRAMES:// 传入真实帧数量未达到固定阈值,无预测帧生成,基础内插模式传入真实帧数量<2时返回该状态码,此时不要将预测帧送显break;default:// 预测帧生成失败return false;}} else { // 真实帧渲染阶段            // 绘制缓存中的上一帧真实帧// ...// 绘制UI// ...// 渲染当前帧渲染画面,缓存颜色、深度、相机矩阵等信息,用于下一帧预测帧生成// ...// 送显缓存中的上一帧真实帧// ...}
}
  1. 调用[HMS_FG_DestroyContext_GLES]接口销毁超帧实例,释放内存资源。
// 销毁超帧上下文实例并释放内存资源
errorCode = HMS_FG_DestroyContext_GLES(&context_);
if (errorCode != FG_SUCCESS) {return false;
}

最后呢

很多开发朋友不知道需要学习那些鸿蒙技术?鸿蒙开发岗位需要掌握那些核心技术点?为此鸿蒙的开发学习必须要系统性的进行。

而网上有关鸿蒙的开发资料非常的少,假如你想学好鸿蒙的应用开发与系统底层开发。你可以参考这份资料,少走很多弯路,节省没必要的麻烦。由两位前阿里高级研发工程师联合打造的《鸿蒙NEXT星河版OpenHarmony开发文档》里面内容包含了(ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等鸿蒙(Harmony NEXT)技术知识点

如果你是一名Android、Java、前端等等开发人员,想要转入鸿蒙方向发展。可以直接领取这份资料辅助你的学习。下面是鸿蒙开发的学习路线图。

在这里插入图片描述

针对鸿蒙成长路线打造的鸿蒙学习文档。话不多说,我们直接看详细鸿蒙(OpenHarmony )手册(共计1236页)与鸿蒙(OpenHarmony )开发入门视频,帮助大家在技术的道路上更进一步。

  • 鸿蒙 (OpenHarmony)开发学习视频》
  • 鸿蒙生态应用开发V2.0白皮书》
  • 鸿蒙 (OpenHarmony)开发基础到实战手册》
  • OpenHarmony北向、南向开发环境搭建
  • 鸿蒙开发基础》
  • 鸿蒙开发进阶》
  • 鸿蒙开发实战》

在这里插入图片描述

总结

鸿蒙—作为国家主力推送的国产操作系统。部分的高校已经取消了安卓课程,从而开设鸿蒙课程;企业纷纷跟进启动了鸿蒙研发。

并且鸿蒙是完全具备无与伦比的机遇和潜力的;预计到年底将有 5,000 款的应用完成原生鸿蒙开发,未来将会支持 50 万款的应用。那么这么多的应用需要开发,也就意味着需要有更多的鸿蒙人才。鸿蒙开发工程师也将会迎来爆发式的增长,学习鸿蒙势在必行! 自↓↓↓拿
1


http://www.ppmy.cn/server/112764.html

相关文章

pyro ExponentialLR 如何设置优化器 optimizer的学习率 pytorch 深度神经网络 bnn,

第一。pyro 不支持 “ReduceLROnPlateau” &#xff0c;因为需要Loss作为输入数值&#xff0c;计算量大 pytorch的学习率调整 视频 看这个博主的视频 05-01-学习率调整策略_哔哩哔哩_bilibili 第二 &#xff0c;svi 支持 scheduler注意点&#xff0c; 属于 pyro.optim.PyroOp…

【深度学习详解】Task2 分段线性模型-引入深度学习 Datawhale X 李宏毅苹果书 AI夏令营

前言 《苹果书》第一章的内容包括 机器学习基础 -> 线性模型 -> 分段线性模型 -> 引入深度学习 这一篇章我们继续后续内容 ~ 其中涉及到“激活函数”的作用理解&#xff1a; 除了 开源项目 - 跟李宏毅学深度学习(入门) 之外&#xff0c; 还有 3Blue1Brown 的神经网络…

SpringBoot实现前后端传输加密设计

在Web应用中&#xff0c;确保前后端之间的数据传输安全是非常重要的。这通常涉及到使用HTTPS协议、数据加密、令牌验证等安全措施。本文通过将前后端之间的传输数据进行加密&#xff0c;用于在Spring Boot应用中实现前后端传输加密设计。 一、数据加密方案 即使使用了HTTPS&…

SpringBoot依赖之Spring Boot DevTools热部署开发增效工具

摘要&#xff1a;Spring项目又大又重&#xff0c;依赖多&#xff0c;编译启动慢&#xff0c;怎么提高研发效率呢&#xff1f;方法之一热部署&#xff01; 概念 Spring Boot DevTools 依赖名称: Spring Boot DevTools功能描述: Provides fast application restarts, LiveRelo…

集成电路学习:什么是DMA直接内存访问

DMA&#xff1a;直接内存访问 DMA&#xff0c;全称Direct Memory Access&#xff0c;即直接内存访问&#xff0c;是一种用于在计算机系统中实现数据传输的技术。以下是对DMA的详细解释&#xff1a; 一、DMA定义与原理 DMA技术允许外围设备&#xff08;如磁盘驱动器、网卡…

什么酱酒能收藏几十年?快来打造你的私人酒窖宝藏

如果说有什么能穿越时空&#xff0c;既不失风雅又能保值增值的“液体黄金”&#xff0c;那非白酒莫属了。 要知道&#xff0c;白酒可是个“不老传说”&#xff0c;它没有明确标注的保质期&#xff0c;却悄悄藏着一个最佳饮用期的秘密。 这就像是一场与时间的游戏&#xff1a;早…

828华为云征文|部署内容管理系统 Joomla

828华为云征文&#xff5c;部署内容管理系统 Joomla 一、Flexus云服务器X实例介绍1.1 云服务器介绍1.2 应用场景1.3 核心竞争力 二、Flexus云服务器X实例配置2.1 重置密码2.2 服务器连接2.3 安全组配置 三、部署 Joomla3.1 Joomla 介绍3.2 Docker 环境搭建3.3 Joomla 部署3.4 J…

【原创教程】电气制图03:EPLAN绘图中图框问题

我们在用EPLAN绘制电气图纸的时候,你有没有遇到过在我们更新项目报表后,目录和其他报表与整个项目的图框不一致的情况,在遇到这样的问题时我们应该怎样解决呢? 如下图所示:图1是我们项目用的图框 图2是我们更新报表后的图框 当我第一次遇到这种情况的时候,我是这样操作的…