Opentcs 光灵开发手册 (一)

2024-03-22 16:59
文章标签 开发 手册 opentcs 光灵

本文主要是介绍Opentcs 光灵开发手册 (一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

序言:

光会刺痛你的双眼,而黑暗不会,但是我光灵愿意牺牲自己以成就黑暗

 

1、opentcs系统需求

1.1、系统需求openTCS源代码是用Java编写的。要编译它,我们开发人员需要一个Java开发工具包(JDK) 1.8或更高版本。要运行生成的二进制文件,您需要一个Java运行时环境(JRE) 1.8或更高。所有其他所需的库都包含在openTCS分发版中,或者在从源代码构建时自动下载。

 

1.2、可用工件和API兼容性

【我们可以联系到maven、gradle相关知识】

openTCS项目通过JCenter发布发布工件,因此我们开发人员可以轻松地将它们与诸如Gradle或Maven之类的构建系统集成。例如,在Gradle构建脚本中,使用下面这样的东西来集成openTCS库:

 

设置我们实际想要使用的openTCS版本的版本号,并从下表中选择合适的${工件}名称:

 

表1、由openTCS项目发布的工件

Artifact name

API compatibility between minor releases

Content

opentcs-api-base

Yes

Contains the base API for clients and extensions. This is what most developer’s probably want to use.

opentcs-api-injection

Yes

Contains API interfaces and classes used for dependency injection within the kernel and plant overview applications. This is required in integration projects customizing these applications, e.g. adding components like vehicle driver implementations.

opentcs-common

No

Contains a collection of utility classes used by openTCS components.

Artifact name

API compatibility between minor releases

Content

opentcs-commadapter-

loopback

No

Contains a very basic vehicle driver simulating a virtual vehicle.

不错啊~~挺帅气的

opentcs-strategies-

default

No

Contains the default implementations of strategies that are used by the kernel application.

opentcs-kernel

No

Contains the kernel application.

opentcs-

kernelcontrolcenter

No

Contains the kernel control center application.

opentcs-plantoverview

No

Contains the plant overview application.

 

注意,只有基本的API库提供了一个文档化的API,openTCS开发人员试图在小版本之间保持兼容。(对于这些库,应用了语义版本控制规则。)所有其他工件的内容都可以并且将会改变,而不考虑任何兼容性问题,因此如果您使用这些并切换到不同版本的openTCS,我们开发人员可能需要调整和重新编译我们的代码。

 

1.3、第三方依赖

1.3.1、内核和客户机应用程序(The kernel and the client applications )依赖于以下外部框架和库:

  • SLF4J (https://www.slf4j.org/): 一个简单的日志外观,以保持实际日志实现的可替换性。

 

  • Google Guice (https://github.com/google/guice): 轻量级依赖注入框架

 

  • Cfg4j (http://www.cfg4j.org/): 支持绑定接口的配置库

 

  • Google Guava (https://github.com/google/guava): 细节上,具有帮助性的类和方法的集合。

 

1.3.2、内核应用程序(The kernel application)还依赖于以下库:

 

•JGraphT (http://jgrapht.org/):用于处理图形并在其上使用算法的库。

 

•Spark (http://sparkjava.com/):用于创建web应用程序的框架。

 

•Jackson (https://github.com/FasterXML/jackson):为Java对象提供JSON绑定。

 

•JDOM (http://www.jdom.org/):用于读写XML数据的库。

 

1.3.3、工厂概述应用程序(The plant overview application)有以下附加的依赖:

 

•JHotDraw (http://www.jhotdraw.org/):绘制图形结构的框架(如车辆行驶课程的模型)。

 

•对接框架(http://www.docking-frames.org/):一个GUI面板停靠对接和卸载的框架

 

1.3.4、对于自动测试,使用以下依赖项:

 

•JUnit (http://junit.org/junit4/):一个简单的单元测试框架。

 

•JUnitParams (https://pragmatists.github.io/JUnitParams/):为JUnit提供了改进的参数化测试支持。

 

•Mockito (http://mockito.org/):用于创建模拟对象的框架。

 

•Hamcrest (http://hamcrest.org/):用于断言匹配器的框架,可用于测试。

 

在构建应用程序时,会自动下载这些依赖项的构件。

1.4、模块化和可扩展性

openTCS项目严重依赖于Guice进行依赖注入和组件连接,以及提供插件式扩展机制。在注入API中,相关类可以在包org.opentcs. customize中找到。例如,请参见定制和扩展内核应用程序、定制和扩展工厂概览应用程序以及定制和扩展控制中心应用程序。openTCS项目严重依赖于Guice进行依赖注入和组件连接,以及提供插件式扩展机制。在注入API中,相关类可以在包org.opentcs.customizations中找到。例如,请参见定制和扩展内核应用程序(the kernel application)、定制和扩展工厂概览应用程序( plant overview application )以及定制和扩展控制中心应用程序( control center application)。

 

1.5、日志记录

官方openTCS发行版中的代码使用SLF4J进行日志记录。因此,通过将SLF4J绑定替换到各自应用程序的类路径中,实际的日志实现是很容易互换的。内核和工厂概述客户端应用程序(The kernel and plant overview client applications),在缺省情况下,附带了SLF4J的java.util.logging绑定日志记录。有关如何更改实际日志实现的更多信息,例如使用log4j,我们开发人员可以参阅SLF4J文档。

 

1.6、使用openTCS源代码(重点学会使用)

openTCS项目本身使用Gradle作为它的构建管理工具。要从源代码构建openTCS,只需从源分布的主目录运行gradlew构建。有关如何使用Gradle的详细信息,请参阅其文档。这些是我们开发人员需要知道的根项目的主要级别任务:

1.6.1、构建:编译所有子项目的源代码。

1.6.2、发布:构建并将所有系统组件打包到构建中。

1.6.3、清理:清理其他任务产生的所有东西,要在IDE中使用源代码,请参阅IDE的文档,以进行渐变集成。对于任何特定的IDE,都没有通用的建议。但是请注意,openTCS源代码包含了使用NetBeans GUI构建器创建的GUI组件。如果我们开发人员想要编辑这些,我们可能想要使用NetBeans IDE。如果我们使用NetBeans,请从NetBeans插件门户安装Gradle支持插件。

然后,您应该能够将源分布的根目录作为一个Gradle项目打开,并从NetBeans中编译和运行组件。

 

这篇关于Opentcs 光灵开发手册 (一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/835750

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

v0.dev快速开发

探索v0.dev:次世代开发者之利器 今之技艺日新月异,开发者之工具亦随之进步不辍。v0.dev者,新兴之开发者利器也,迅速引起众多开发者之瞩目。本文将引汝探究v0.dev之基本功能与优势,助汝速速上手,提升开发之效率。 何谓v0.dev? v0.dev者,现代化之开发者工具也,旨在简化并加速软件开发之过程。其集多种功能于一体,助开发者高效编写、测试及部署代码。无论汝为前端开发者、后端开发者

pico2 开发环境搭建-基于ubuntu

pico2 开发环境搭建-基于ubuntu 安装编译工具链下载sdk 和example编译example 安装编译工具链 sudo apt install cmake gcc-arm-none-eabi libnewlib-arm-none-eabi libstdc++-arm-none-eabi-newlib 注意cmake的版本,需要在3.17 以上 下载sdk 和ex