首页 > 其他分享 >Chai 3D :组件工具

Chai 3D :组件工具

时间:2023-03-15 13:22:11浏览次数:52  
标签:create Chai namespace chai3d 字体 组件 using assign 3D

推荐:将 NSDT场景编辑器 加入你的3D开发工具链

介绍

  在 CHAI3D 中,小部件是以 2D 形式显示数据和状态信息的主要元素。每个摄像机都包含一个前层和后层,可以在其上附加小部件。渲染摄像机场景时,首先渲染 2D 背景图层,然后渲染 3D 世界,最后渲染 2D 前图层。

在下一节中,我们将回顾其中一些基本小部件。

CHAI3D中的小部件

面板

  cPanel 可用于在窗口上放置一个空面板。面板具有用于提供圆角、颜色和材料纹理属性的属性。面板由其宽度定义,高度可以放置在视口中的任何位置。

using namespace chai3d;
// create a panel
cPanel* panel = new cPanel();
// add panel to front layer of camera
camera->m_frontLayer->addChild(panel);
// set width and height of panel
panel->setSize(300, 200);
// assign radius of each corner of panel
panel->setCornerRadius(10, 10, 10, 10);
// assign a position (x,y) to panel
panel->setLocalPos(40, 60);
// set a uniform color to panel
panel->setColor(cColorf(1.0, 0.5, 0.5));
// assign a transparency level to panel
panel->setTransparencyLevel(0.5);

位图

  应用程序可以将位图小组件添加到其用户界面以显示图像。图像及其原点显示在微件目标矩形的左下角,并且可以沿 X 轴和 Y 轴拉伸。

using namespace chai3d;
// create bitmap object
cBitmap* bitmap = new cBitmap();
// add bitmap to front layer of camera
camera->m_frontLayer->addChild(bitmap);
// load image file
bitmap->loadFromFile("myImage.png");

背景

  背景构件可用于显示覆盖整个显示窗口的图像。

// create a background object
cBackground* background = new cBackground();
// add background to back layer of camera
camera->m_backLayer->addChild(background);
// set aspect ration of background image a constant
background->setFixedAspectRatio(true);
// load an image file
background->loadFromFile("myImage.png");

示例 05-字体:背景图像覆盖整个窗口

水平仪

  水平仪是一个线性仪表小部件,用于让用户快速了解值在一定范围内的位置。水平可以水平或垂直设置。

using namespace chai3d;
// create dial object
level = new cLevel();
// add level to front layer of camera
camera->m_frontLayer->addChild(level);
// set range of values displayed by level
level->setRange(0.0, 0.1);
// set size of level
level->setSize(40);
// enable single line display option
level->setSingleIncrementDisplay(true);
// assign value to level
level->setValue(value);

水平仪可以通过旋转小部件 90 度来水平设置。

using namespace chai3d;
// rotate level of 90 degrees angle
level->rotateWidgetDeg(90);

表盘

表盘提供与水平仪类似的功能,但采用圆形显示。

拨盘:(左)连续显示(右)单增量显示

using namespace chai3d;
// create dial object
dial = new cDial();
// add dial to front layer of camera
camera->m_frontLayer->addChild(dial);
// set range of values displayed by dial
dial->setRange(-0.1, 0.1);
// set size of dial
dial->setSize(40);
// enable single line display option
dial->setSingleIncrementDisplay(true);
// assign value to dial
dial->setValue(value);

示波器

  应用程序可以添加一个 cScope 小部件,以显示多达四个类似于数字示波器的不同信号。

using namespace chai3d;
// create a background object
scope = new cScope();
// add scope to back layer of camera
camera->m_frontLayer->addChild(scope);
// assign a position (x,y) to panel
scope->setLocalPos(100,60);
// set range of signal values (min / max)
scope->setRange(-0.1, 0.1);
// enable signals for display
scope->setSignalEnabled(true, true, true, false);
// assign a transparency level to scope
scope->setTransparencyLevel(0.7);

初始化示波器后,可以使用以下命令持续更新信号值:

using namespace chai3d;
// assign signal values
scope->setSignalValues(value0, value1, value2, value3);

标签

  标签是用于在应用程序中添加文本的小部件。对于每个标签,将分配一种字体。字体应始终在实例化标签之前创建,并且可以在多个标签之间共享。

using namespace chai3d;
// create a font
cFont* font = NEW_CFONTCALIBRI20();
// create a label
cLabel* label = new cLabel(font);
// add label to front layer of camera
camera->m_frontLayer->addChild(label);
// assign color to label
label->m_fontColor.setBlack();
// assign text to label
label->setText("my message");
// position widget on screen
label->setLocalPos(100, 120);

字体

  CHAI3D 支持使用位图字体,位图字体由包含字体中所有必需字母的纹理图集和描述该纹理图集上每个字母的位置和大小的文本数据文件组成。

  所选字体在 CHAI3D 框架中编码,并可以使用以下代码进行实例化。编码字体的完整列表可以在 src/resources 目录中找到。

using namespace chai3d;
// create a font (Calibri Size 20)
cFont* font1 = NEW_CFONTCALIBRI20();
// create a font (Calibri Size 36)
cFont* font2 = NEW_CFONTCALIBRI36();

字体也可以使用应用程序BMFont从AngelCode生成的字体文件加载。

using namespace chai3d;
// create a font
cFont* font = new cFont();
// load font from file
font->loadFromFile("myFont.fnt");

使用 BMFont 创建位图字体

步骤1

运行 BMFont 并打开选项->字体设置。

步骤2

1、从PC上已安装的字体列表中选择所需的字体,或添加硬盘驱动器上的字体文件。

2、设置字体的像素大小并选中匹配字符高度。

3、检查 字体平滑 和 超级采样 如果您希望字母平滑且消除锯齿。

步骤3

1、然后回到主工具窗口,您将看到所选字体中包含的所有字母。

2、突出显示您希望包含在字体中的所有字母,通过打开/关闭每个字母或从右侧列表中切换字母的子部分来单独突出显示。

步骤4

1、接下来,打开选项->导出选项。

2、根据您选择的字体,以及是否要向纹理图集添加任何后期效果,您可能需要添加一些字母填充以防止字母上出现意外的伪影。

3、设置纹理图集的宽度和高度。它需要足够大,以便将所有字母放入一个纹理上。要检查它是否适合所选大小,请返回主窗口并按“V”或转到选项->可视化。

4、最好是坚持使用地图集的 2 次幂维度。例如 2,4,8,16,32,64,128,256,512 等。

5、检查32位深度以允许alpha通道。

6、选中文本文件格式,并检查 PNG 作为纹理格式。

步骤5

1、选择选项->将位图字体另存为...

2、将位图字体保存到 CHAI3D 资源文件夹。

3D建模学习工作室翻译整理,转载请标明出处!

标签:create,Chai,namespace,chai3d,字体,组件,using,assign,3D
From: https://www.cnblogs.com/mvrlink/p/17218150.html

相关文章

  • Quartz组件的搭建及实现任务调度demo
    1.基本环境配置<dependency>​<groupId>org.slf4j</groupId>​<artifactId>slf4j-log4j12</artifactId>​<version>1.7.25</version>​</dependency><d......
  • VUE基础:组件CSS样式、props属性
    VUE基础部分组件css样式例子<stylelang="less">//这里记得改名,然后给div也加名字.comName-container{padding:1020px20px;background-color:lightskyblue......
  • 子组件的创建与隐藏
    子组件的创建与隐藏通过flag的切换,进行子组件Test的创建和隐藏。App.vue<button@click="flag=!flag">ToggleFlag</button><Testv-if="flag"></Test>......
  • 组件的使用:全局、私有
    全局组件使用创建@/components/Count.vue,定义其内容①main.js导入importCountfrom'@/components/Count.vue'声明Vue.component('myCount',Count)//这里的myCou......
  • 谁会拒绝一个开源的 3D 博客呢?
    说到博客大家一定都不陌生,不管你是深耕职场多年的老鸟,还是在学校努力学习的小鸟,应该都有过一段“装扮”博客的经历,比如:放上喜欢的图片、添加炫酷的交互、换上DIY的博客......
  • PyQt-Fluent-Widgets:一个 Fluent Design 风格的组件库
    简介这是一个使用PyQt/PySide编写的FluentDesign风格的组件库,包含最常用的组件,支持亮暗主题无缝切换。实际上此项目是从GrooveMusic项目剥离出来的子项目,github......
  • Kubernetes组件介绍
    一、APIserver1、APIServer是Kubernetes集群的网关,是能够与etcd通信惟一入口(1)kube-controller-manager、kube-scheduler、kubelet、kube-proxy,以及后续部署的集群插件Co......
  • ReferIt3D 论文精读
    Scanrefer才是本系列的开山之作,但是提出比较优秀的数据集且后期有一系列完善模型工作的,还是ReferIt3D比较优秀一些,那么ReferIr3D究竟做了些什么呢?跟着小编一起来看一看吧!......
  • 权限认证组件和自定义权限
    1.权限组件源码分析:  2.自定义权限超级用户类_app_auth.py:  3.在部分接口内局部添加超级用户权限_仅提供于超级用户查看:  4.在全部添加超级用户权限_......
  • [Vue3] 组件上的ref不能与组件名相同
    情景关键组件没有正确引入函数无限递归解决如果在网上搜索[Vuewarn]:Componentismissingtemplateorrenderfunction.或[Vuewarn]:Invalidvnodetype......