openFrameworks_如何使用ofxXmlSettings和ofxGui来创建识别界面
效果图:
代码及详解
1.添加两个插件的头文件:
#include "ofxGui.h"
#include "ofxXmlSettings/src/ofxXmlSettings.h"
2.添加GUI部分,然后在.h声明右边的openframeworks的UI部分,包括面板ofxPanel,按钮ofxButton,滑块ofxSlider,切换ofxToggle,组ofxGuiGroup:
ofxPanel panel;
ofxToggle ip;
ofxIntSlider port;
ofxIntSlider device;
ofxToggle cutFilter;
ofxGuiGroup depthGroup;
ofxToggle useDepth;
ofxToggle base;
ofxIntSlider deviceX;
ofxIntSlider deviceY;
ofxIntSlider gridX;
ofxIntSlider gridY;
ofxButton save;int portInt = 3333;
int deviceXInt = 1;
int deviceYInt = 1;
int gridXInt = 2;
int gridYInt = 2;
3. 在ofApp::setup()函数中对变量赋值:
panel.setPosition(250, 0);
panel.setup("Values", "toolsConfig", 250, 0);
panel.setName("Values");
panel.add(ip.setup("ip", false));
panel.add(port.setup("port", 3333, 3333, 3350));
panel.add(device.setup("device", 0, 0, 3));
panel.add(cutFilter.setup("cutFilter", false));
depthGroup.setup("depthGroup");
depthGroup.setName("depthGroup");
depthGroup.add(useDepth.setup("useDepth", false));
depthGroup.add(base.setup("base", false));
depthGroup.minimize();
panel.add(&depthGroup);panel.add(deviceX.setup("deviceX", 1, 1, 6));
panel.add(deviceY.setup("deviceY", 1, 1, 6));
panel.add(gridX.setup("gridX", 2, 2, 10));
panel.add(gridY.setup("gridY", 2, 2, 10));
panel.add(save.setup("save"));
panel.minimizeAll();panel.loadFromFile("toolsConfig.xml");
gui.setPosition(250, 0);//设置panel的位置
gui.setup("Values", "toolsConfig", 250, 0);//设置名称,位置和config
panel.setName("Values");//设置panel的名称
panel.add(ip.setup("ip", false));//将ip的名字设置在UI上,并记录点击切换后的数值
panel.add(port.setup("port", 3333, 3333, 3350));//同上
panel.add(device.setup("device", 0, 0, 3));//同上
panel.add(cutFilter.setup("cutFilter", false));//同上
depthGroup.setup("depthGroup");//设置组
depthGroup.setName("depthGroup");//设置组名称
depthGroup.add(useDepth.setup("useDepth", false));//组内添加useDepth,并设置false
depthGroup.add(base.setup("base", false));//同上
depthGroup.minimize();//将组最小化
panel.add(&depthGroup);//将组添加到panel中
panel.add(deviceX.setup("deviceX", 1, 1, 6));//设置水平方向设备数量
panel.add(deviceY.setup("deviceY", 1, 1, 6));//设置竖直方向设备数量
panel.add(gridX.setup("gridX", 2, 2, 10));//设置调试点水平方向数量
panel.add(gridY.setup("gridY", 2, 2, 10));//设置调试点竖直方向数量
panel.add(save.setup("save"));//设置保存按钮及名称
panel.minimizeAll();
panel.loadFromFile("toolsConfig.xml");//加载一个名为"toolsConfig.xml"的配置文件到panel对象
//设置背景颜色
ofSetBackgroundColor(ofColor::cornflowerBlue);
//对滑块添加监听事件
device.addListener(this, &ofApp::deviceChange);
4.ofApp::draw()函数中对调用绘制方法:
panel.draw();
5.添加xml外部配置,在.h中声明ofxXmlSettings的变量
ofxXmlSettings xml;
6.在ofApp::setup()函数中对xml调用:
xml.loadFile("config.xml");
7.按保存按键对UI上的数值进行保存:
if(save){xml.setValue("ip", ip == false ? "127.0.0.1" : "192.168.0.2");xml.setValue("port", port);xml.setValue("device", device);xml.setValue("cutFilter", cutFilter);xml.setValue("useDepth", useDepth);xml.setValue("base", base);xml.setValue("gridX", gridXInt - 1);xml.setValue("gridY", gridYInt - 1);xml.setValue("deviceX", deviceXInt);xml.setValue("deviceY", deviceYInt);xml.saveFile("config.xml");panel.saveToFile("toolsConfig.xml");
}
//设置xml中相应的参数并存入xml外部配置中,其他的同理
xml.setValue("ip", ip == false ? "127.0.0.1" : "192.168.0.2");
7.添加相应的介绍,在.h中声明函数:
void description();
8.在ofApp::draw()函数中对调用介绍方法:
void ofApp::draw() {panel.draw();description();
}
9.description()方法中的代码如下:
void ofApp::description() {selectFont(18, DEFAULT_CHARSET, "宋体");ofSetColor(ofColor::white);drawCNString(ip == false ? "ip地址:127.0.0.1" : "ip地址:192.168.0.2", 20, 35);drawCNString(("端口号:" + ofToString(portInt)).c_str(), 20, 55);drawCNString(("设备类别:" + ofToString(deviceName)).c_str(), 20, 75);drawCNString(cutFilter == false ? "滤光片状态:初始不切换" : "滤光片状态:初始切换", 20, 95);drawCNString(useDepth ? "图像类别:深度图像" : "图像类别:红外图像", 20, 115);if (deviceType == 0 || deviceType == 1) {drawCNString("测距基准:无", 20, 135);}else {if (useDepth) {drawCNString(base ? "测距基准:识别设别" : "测距基准:被测环境", 20, 135);}else {drawCNString("测距基准:无", 20, 135);}}drawCNString(("水平摄像头数量:" + ofToString(deviceXInt)).c_str(), 20, 155);drawCNString(("垂直摄像头数量:" + ofToString(deviceYInt)).c_str(), 20, 175);drawCNString(("水平校准点数量:" + ofToString(gridXInt)).c_str(), 20, 195);drawCNString(("垂直校准点数量:" + ofToString(gridYInt)).c_str(), 20, 215);}
10.切换device所执行的方法代码如下:
void ofApp::deviceChange(int& device)
{switch (device){case 0:deviceName = "普通摄像头";useDepth = false;width = 640;height = 480;depthGroup.minimize();break;case 1:deviceName = "可切换滤光片";useDepth = false;width = 640;height = 480;depthGroup.minimize();break;case 2:deviceName = "Kinect2";useDepth = true;width = 512;height = 424;depthGroup.minimize();depthGroup.maximize();break;case 3:deviceName = "奥比中光";useDepth = true;width = 640;height = 480;depthGroup.minimize();depthGroup.maximize();break;default:break;}
}
最终的效果已经发在文章的开篇了
给个关注,接下来这些天我将手把手教你使用openframeworks制作一个多媒体互动的识别软件。
相关文章:

openFrameworks_如何使用ofxXmlSettings和ofxGui来创建识别界面
效果图: 代码及详解 1.添加两个插件的头文件: #include "ofxGui.h" #include "ofxXmlSettings/src/ofxXmlSettings.h" 2.添加GUI部分,然后在.h声明右边的openframeworks的UI部分,包括面板ofxPanel,按钮ofx…...

180多个GIS地理空间定义术语中英文对照配图
主动传感器(Active Sensors): [遥感]主动传感器照亮其目标,并测量返回到传感器的反射后向散射。 邻接(Adjacency): [几何]邻接发生在两个对象共享同一边界,并且与公共边或顶点相邻…...

Vue(14)——组合式API①
setup 特点:执行实际比beforeCreate还要早,并且获取不到this <script> export default{setup(){console.log(setup函数);},beforeCreate(){console.log(beforeCreate函数);} } </script> 在setup函数中提供的数据和方法,想要在…...

【图像检索】基于颜色模型的图像内容检索,matlab实现
博主简介:matlab图像代码项目合作(扣扣:3249726188) ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 本次案例是基于颜色模型的图像内容检索,用matlab实现。 一、案例背景和算法介绍 这…...

看过来——量子计算中一个神奇符号的解释
量子计算中一个神奇符号是 H ⊗ n \mathcal{H}^{\otimes n} H⊗n 它代表什么呢, 往下看 H ⊗ n \mathcal{H}^{\otimes n} H⊗n 通常在量子力学中表示 n次张量积的希尔伯特空间。 H \mathcal{H} H 表示一个希尔伯特空间,这是量子力学中描述量子态的空间&…...

传输层 IV(TCP协议——流量控制、拥塞控制)【★★★★】
(★★)代表非常重要的知识点,(★)代表重要的知识点。 一、TCP 流量控制(★★) 1. 利用滑动窗口实现流量控制 一般说来,我们总是希望数据传输得更快一些。但如果发送方把数据发送得…...

Java设计模式全面解析
23大设计模式(即软件设计中的24种常用设计模式)源自《设计模式:可复用面向对象软件的基础》一书,由四位作者(Erich Gamma、Richard Helm、Ralph Johnson、John Vlissides)提出,通常也被称为“Go…...

spring全家桶使用教程
Spring 全家桶是指围绕 Spring 框架构建的一系列子项目和工具,涵盖了企业级应用开发的多个方面,如依赖注入、数据访问、事务管理、Web 开发、消息队列、云服务等。通过 Spring 全家桶,开发者可以构建从简单的 Web 应用到复杂的微服务架构。 …...

REST-系统架构师(六十九)
1某公司内部的信息系统集成,需要实现在系统之间快速传递可定制格式的数据包,并且当有新的数据包到达时候,接收系统会自动得到通知。另外还要支持数据重传,以确保传输的成功。针对这些需求,应该采用(&#x…...

SAP B1 营销单据 - 复制从复制到总结
背景 营销单据具有相似的表单结构,并且单据之间可互相复制,本文总结出各个单据可【复制从】与【复制到】的单据清单,并绘制流程图,表现理论上可完成的流程。 销售:销售报价单;销售订单;交货&am…...

css设置overflow:hiden行内元素会发生偏移的现象
父级元素包含几个行内元素 <div id"box"><p><span>按钮</span><span>测试文字文字文字测试文字文字文字</span><span>看这里</span></p></div>#box p{width: 800px;font-size: 30px;}#box p span{disp…...

使用多个 GitHub 账号的 SSH 配置与常见问题排查
文章目录 使用多个 GitHub 账号的 SSH 配置与常见问题排查摘要目录1. 使用多个 GitHub 账号的场景介绍2. 配置多个 SSH 密钥2.1 生成多个 SSH 密钥2.2 添加 SSH 密钥到 SSH 代理2.3 将 SSH 公钥添加到 GitHub 账户 3. 配置 SSH 代理与 GitHub 账户的关联3.1 为不同仓库设置不同…...

sql语法学习
学习 SQL(Structured Query Language)语法是数据库开发的基础,主要用于数据库的管理和操作。以下是 SQL 的基本语法和常用操作,涵盖数据查询、插入、更新、删除等。 1. 数据库基础 数据库:存储表和数据的集合。表&am…...

滚雪球学SpringCloud[5.3讲]: 配置管理中的高可用与容错
全文目录: 前言高可用配置中心的搭建为什么需要高可用配置中心?多实例与负载均衡数据一致性实战示例:使用Nginx实现高可用配置中心 Spring Cloud Config中的高可用性高可用性的进一步优化 配置管理中的故障处理策略分布式系统中的常见故障故障…...

电商安全新挑战:筑起数字防御长城,守护业务与数据安全
在当今这个数字化时代,电商行业正以前所未有的速度发展,大数据、人工智能等技术的融入不仅重塑了消费模式,更激发了行业新的增长点。然而,这片繁荣景象之下,隐藏着一个不容忽视的暗流——网络安全威胁。从数据泄露到恶…...

Python 单元测试:深入理解与实战应用20240919
Python 单元测试:深入理解与实战应用 引言 在动态语言如 Python 中,代码的灵活性和动态特性使得开发效率大大提升,但也带来了潜在的风险:小的改动可能导致不可预见的功能失效。因此,确保代码逻辑的正确性和稳健性至关…...

二、MySQL环境搭建
文章目录 1. MySQL的卸载步骤1:停止MySQL服务步骤2:软件的卸载步骤3:残余文件的清理步骤4:清理注册表(选做)步骤5:删除环境变量配置 2. MySQL的下载、安装、配置2.1 MySQL的4大版本2.2 软件的下…...

mongoDB 读取数据python版本实现
要使用Python从MongoDB读取数据,你可以使用pymongo库。首先确保你已经安装了pymongo,如果没有安装,可以通过pip来安装它: pip install pymongo 接下来,我将展示如何使用给定的MongoDB连接字符串来连接数据库ÿ…...

java Nio的应用
Java NIO(New Input/Output)是Java 1.4引入的一种非阻塞I/O模型,适用于高性能和高并发的应用程序。以下是NIO的一些主要应用场景和特点: 1. 非阻塞I/O NIO支持非阻塞模式,这意味着线程可以在I/O操作进行时继续执行其…...

双十一有什么好物推荐?值得入手的五款产品
随着双十一狂欢的号角日益临近,这个一年一度的购物盛典即将拉开帷幕!为了让大家在海量的商品中精准定位,圆圆用心整理了一份购物清单,分享那些我亲身试用过,觉得超级值得购买的好物。 这些商品不但价格亲民࿰…...

Nuxt Kit 使用日志记录工具
title: Nuxt Kit 使用日志记录工具 date: 2024/9/23 updated: 2024/9/23 author: cmdragon excerpt: 摘要:本文介绍在Nuxt 3框架的Nuxt Kit中使用日志记录工具的方法,重点讲解useLogger函数的应用,通过创建示例项目一步步展示如何配置和使用日志记录功能来监控应用状态、…...

视频相关处理
1、概念 (1)FPS 是 “Frames Per Second” 的缩写,意思是“每秒帧数”。它表示每秒钟屏幕上显示的图像帧数,用来衡量动画、视频或游戏画面的流畅度。 FPS 越高,画面越流畅,通常来说,30 FPS 被认为是基本流畅,60 FPS 及以上则非常顺滑。FPS 过低 会导致画面卡顿,尤其是…...

关于循环Socket创建超Linux文件句柄限制现象分析
项目场景: 在操作系统的世界中万物皆文件。之前拜读过一些作品:针对于socket的创建,Linux也相应创建文件(专业术语中也称文件句柄),于是,我想做一些关于极限的操作,看看这些极限操作…...

简单说说MySQL中 SELECT 语句执行流程
流程讲解 MySQL 中 SELECT 语句的执行流程分为多个步骤,通常从用户发出查询请求到 MySQL 返回结果包含以下过程: 客户端/服务器通信: 用户向 MySQL 服务器发送 SELECT 查询语句。 查询解析(Parser): MySQ…...

国产游戏技术:迈向全球引领者的征途
目录 国产游戏技术能否引领全球? 一、国产游戏技术的崛起之路 1.1 初期探索与积累 1.2 技术创新的加速 1.3 文化自信的体现 二、国产游戏技术的核心竞争力 2.1 本地化与定制化策略 2.2 技术创新与应用 2.3 产业链协同与生态构建 三、面临的挑战与应对策略…...

小程序体验版无法正常请求接口,开启 调试可以正常请求
在本地开发工具可以正常访问小程序,上传代码后打开体验版,界面无法请求接口,手机小程序打开调试模式可以正常访问。这可以查看下小程序后台是否设置了服务器域名以及业务域名 然后查看小程序开发工具 - 详情 - 项目配置 重新上传代码…...

什么是动态数据脱敏?
原文地址 https://www.bytebase.com/blog/what-is-dynamic-data-masking/ 动态数据脱敏(DDM)动态更改返回给应用程序或用户的数据库记录,以此来实时保护敏感数据,且不会更改静态数据。 DDM 与静态数据脱敏(SDM&#x…...

【机器学习】11——矩阵求导
机器学习11——矩阵求导 打公式不太好标注,全图警告!!! 文章目录 机器学习11——矩阵求导1.1标量对向量1.2标量对矩阵2.1向量对标量2.2向量对向量2.3向量对矩阵 1.1标量对向量 1.2标量对矩阵 X是m*n的矩阵,不严谨&am…...

Spring Boot 实战:结合策略模式实现动态定价服务
引言 在现代商业环境中,价格策略的灵活性对于吸引客户和提高市场竞争力至关重要。传统的定价方法往往固定不变,而随着市场的变化和技术的发展,能够根据不同的条件和场景来调整价格的动态定价策略变得越来越重要。Spring Boot 框架以其简洁的…...

Serverless架构
Serverless架构:漂浮在云端的轻盈与自由 类似于 Fn Project 的 Serverless 开源服务有很多,它们都旨在简化函数即服务(FaaS)的开发流程,使得开发者可以更专注于业务逻辑而不是底层基础设施。下面列举了一些知名的 Serverless 开源平台和服务…...