- Debugging/Logging - 飞行日志分析
- Debugging/Logging - ULog文件格式
- 教程
- 教程 - 地面站
- 教程 - 编写应用程序
- 教程 - QGC的视频流
- 教程 - 远距离视频流
- 教程 - u-blox M8P RTK
- 新手上路
- 新手上路 - 初始设置
- 新手上路 - 安装工具链
- 安装工具链 - Mac OS
- 安装工具链 - Linux
- Linux - Advanced Linux
- 安装工具链 - Windows
- 新手上路 - Fast RTPS installation
- 新手上路 - 代码编译
- 新手上路 - 高级配置
- 新手上路 - 贡献& 开发者电话会议
- 贡献& 开发者电话会议 - GIT例程
- 贡献& 开发者电话会议 - Documentation
- 新手上路 - Licenses
- 概念解读
- 概念解读 - 飞行模式
- 概念解读 - 结构概述
- 概念解读 - 飞行控制栈
- 概念解读 - 中间件
- 概念解读 - 混控和执行器
- 概念解读 - PWM限制状态机
- Hardware
- Hardware - 自驾仪硬件
- 机型 - 统一的基础代码
- 机型 - 参考机型
- 机型 - 添加一个新的机型
- Data Links - SiK Radio
- Data Links - Wifi数传
- Data Links - 数传
- I2C总线 - SF1XX lidar
- 传感器和执行机构总线 - UAVCAN总线
- UAVCAN总线 - UAVCAN Bootloader
- UAVCAN总线 - UAVCAN固件升级
- UAVCAN总线 - UAVCAN配置
- UAVCAN总线 - UAVCAN 的各种笔记
- 传感器和执行机构总线 - UART
- UART - uLanding Radar
- 传感器和执行机构总线 - 设置云台控制
- 传感器和执行机构总线 - 相机触发器
- Hardware - 协同电脑
- 仿真
- 仿真 - 基本仿真
- 仿真 - Gazebo仿真
- 仿真 - HITL仿真
- 仿真 - 连接到ROS
- 仿真 - AirSim仿真
- 仿真 - 多机仿真
- 中间件及架构
- 中间件及架构 - uORB消息机制
- 中间件及架构 - MAVLink消息机制
- 中间件及架构 - 守护程序
- 中间件及架构 - 驱动框架
- 模块 & 命令
- 模块 & 命令 - 命令
- 模块 & 命令 - 通信
- 模块 & 命令 - 驱动
- 模块 & 命令 - 系统
- Robotics
- Robotics - 用Linux进行外部控制
- Robotics - ROS
- ROS - 在RPi上安装ROS
- ROS - MAVROS (ROS上的MAVLink)
- ROS - MAVROS外部控制例程
- ROS - 外部位置估计
- ROS - Gazebo Octomap
- Robotics - DroneKit
- Debugging/Logging
- Debugging/Logging - FAQ
- Debugging/Logging - 系统控制台
- Debugging/Logging - 自驾仪调试
- Debugging/Logging - Sensor/Topic Debugging
- Debugging/Logging - 仿真调试
- Debugging/Logging - System-wide Replay
- Debugging/Logging - 发送调试的值
- Debugging/Logging - Profiling
- Debugging/Logging - 日志记录
- 教程 - 光流
- 教程 - ecl EKF
- 教程 - 飞行前检查
- 教程 - 着陆检测
- 教程 - Linux系统下使用S.Bus驱动
- Advanced Topics
- Advanced Topics - 系统启动
- Advanced Topics - 参数&配置
- Advanced Topics - 参考参数
- Advanced Topics - 安装Intel RealSense R200的驱动
- Advanced Topics - 切换状态估计器
- Advanced Topics - 外部模块
- Advanced Topics - STM32 Bootloader
- 测试和持续集成
- 测试和持续集成 - 持续集成
- 测试和持续集成 - Jenkins持续集成环境
- 测试和持续集成 - 综合测试
- 测试和持续集成 - Docker容器
- 测试和持续集成 - 维护
新手上路 - 代码编译
PX4可以在控制台或者图形界面/IDE开发
在控制台编译
在去到图形界面或者IDE前,验证系统设置的正确性非常重要,因此打开控制台。在 OS X, 敲击 ⌘-space ,并搜索’terminal’。在Ubuntu,单击启动栏,搜索“terminal”(或者trl+alt+T)。在windows平台,在开始菜菜单找到px4文件夹,单击’PX4 Console’
终端在Home目录启动,我们默认去到’~/src/Firmware’ 然后,克隆顶层资源库。有经验的开发者可以克隆自己的复制的资源库
mkdir -p ~/src
cd ~/src
git clone https://github.com/PX4/Firmware.git
cd Firmware
git submodule update --init --recursive
cd ..
现在可以通过编译源代码来构建二进制文件。在直接使用硬件前,推荐先进行仿真。喜欢在图形界面开发环境工作的用户也应该继续完成下面部分。
基于NuttX / Pixhawk的硬件板
cd Firmware
make px4fmu-v2_default
注意到“make”是一个字符命令编译工具,“px4fmu-v2”是硬件/ardupilot版本,“default”是默认配置,所有的PX4编译目标遵循这个规则。
成功编译的最后输出是这样的:
[100%] Linking CXX executable firmware_nuttx
[100%] Built target firmware_nuttx
Scanning dependencies of target build/firmware_px4fmu-v2
[100%] Generating nuttx-px4fmu-v2-default.px4
[100%] Built target build/firmware_px4fmu-v2
通过在命令后面添加‘upload’,编译的二进制程序就会通过USB上传到飞控硬件:
make px4fmu-v2_default upload
上传成功时输出情况如下:
Erase : [====================] 100.0%
Program: [====================] 100.0%
Verify : [====================] 100.0%
Rebooting.
[100%] Built target upload
Raspberry Pi 2 开发板
以下命令编译生成Raspbian(posix_pi2_release)版本的固件。
cd Firmware
make posix_rpi2_release # for cross-compiler build
“mainapp”可执行文件位于目录build/posix_rpi2_release/src/firmware/posix下。 将其复制到RPi(用你的RPi的IP或主机名替换YOUR_PI,关于如何访问你的RPi,查看介绍)
然后使用以下命令设置你的RPi的IP(或主机名):
export AUTOPILOT_HOST=192.168.X.X
并上传:
cd Firmware
make posix_rpi_cross upload # for cross-compiler build
然后,通过ssh连接并运行它(以root权限):
sudo ./px4 px4.config
本地构建
如果你要直接在Pi上编译,则需要在本地编译固件(posix_rpi_native)。
cd Firmware
make posix_rpi_native # for native build
“px4”可执行文件位于目录build/posix_rpi_native/src/firmware/posix中。直接运行:
sudo ./build/posix_rpi_native/src/firmware/posix/px4 ./posix-configs/rpi/px4.config
px4成功执行的情况如下:
______ __ __ ___
| ___ / / / |
| |_/ / V / / /| |
| __/ / / /_| |
| | / /^ ___ |
_| / / |_/
px4 starting.
pxh>
自启动
要自动启动px4,在exit 0
之前,请将以下内容添加到文件/etc/rc.local
中(如果使用本机构建,请相应调整):
cd /home/pi && ./px4 -d px4.config > px4.log
Parrot Bebop
支持的Bebop是非常早期的版本,使用前请特别注意。
编译
cd Firmware
make posix_bebop_default
打开你的Bebop,通过Bebop的wifi连接你的主机。 然后,按下电源按钮四次以启用ADB并启动telnet守护程序。
make posix_bebop_default upload
以上操作会将PX4 mainapp上传到/usr/bin并创建文件/home/root/parameters(如果尚未存在)。 此外,我们需要Bebop的mixer文件和px4.config。 当前这两个文件必须使用以下命令手动复制。
adb connect 192.168.42.1:9050
adb push ROMFS/px4fmu_common/mixers/bebop.main.mix /home/root
adb push posix-configs/bebop/px4.config /home/root
adb disconnect
运行
连接Bebop的wifi,然后按电源按钮四次。 接下来,通过telnet或adb shell与Bebop连接,并运行以下命令。
telnet 192.168.42.1
通过以下命令关闭Bebop的所有驱动。
kk
启动PX4 mainapp:
px4 /home/root/px4.config
为了飞行Bebop,将操纵杆设备与主机连接并启动QGroundControl。 Bebop和操纵杆都应该被识别。按照说明校准传感器并设置操纵杆设备。
自启动
要使启动时在Bebop上自动启动PX4,请修改init脚本/etc/init.d/rcS_mode_default
。 添加下行:
DragonStarter.sh -out2null &
替换为:
px4 -d /home/root/px4.config > /home/root/px4.log
通过按电源按钮4次启用adb服务器,并按照上述方式连接到adb服务器:
adb connect 192.168.42.1:9050
将系统分区重新挂载为可写:
adb shell mount -o remount,rw /
为了避免手动配置文件,可以使用下面链接: https://gist.github.com/mhkabir/b0433f0651f006e3c7ac4e1cbd83f1e8
保存原来的,并将其推送到Bebop
adb shell cp /etc/init.d/rcS_mode_default /etc/init.d/rcS_mode_default_backup
adb push rcS_mode_default /etc/init.d/
同步并重启
adb shell sync
adb shell reboot
基于QuRT / Snapdragon的开发板
编译
以下命令编译Linux和DSP端的固件。 两个可执行机构通过muORB进行通信。
cd Firmware
make eagle_default
要将SW加载到设备上,通过USB数据线进行连接,并确保设备已启动。 在新的终端窗口中运行:
adb shell
返回上一个终端并上传:
make eagle_default upload
请注意,这也将复制(并覆盖)mainapp.config和px4.config这两个配置文件到设备。 如果你要直接编辑启动脚本,文件路径分别为/usr/share/data/adsp/px4.config和/home/linaro/mainapp.config。
当前需要手动复制mixer
adb push ROMFS/px4fmu_common/mixers/quad_x.main.mix /usr/share/data/adsp
运行
运行DSP调试监视器:
${HEXAGON_SDK_ROOT}/tools/debug/mini-dm/Linux_Debug/mini-dm
注意:如果是在Mac上,你也可以使用nano-dm。
回到ADB shell并运行px4:
cd /home/linaro
./px4 mainapp.config
请注意,只要断开USB数据线(或者ssh会话断开连接),px4就会停止。 如果要飞行,你应该在启动后使px4自动启动。
自启动
要在Snapdragon启动时一直运行px4,可以将启动添加到rc.local
中: 或者直接编辑文件/etc/rc.local
:
adb shell
vim /etc/rc.local
或将文件复制到你的电脑,在本地进行编辑,然后将其复制回来:
adb pull /etc/rc.local
gedit rc.local
adb push rc.local /etc/rc.local
对于自动启动,在 exit 0
之前添加以下行:
(cd /home/linaro && ./px4 mainapp.config > mainapp.log)
exit 0
确保rc.local
是可执行的:
adb shell
chmod +x /etc/rc.local
然后重新启动Snapdragon:
adb reboot
图形IDE界面下编译
PX4 支持Qt Creator, Eclipse 和Sublime Text三种集成式开发环境。 Qt Creator是最友好的开发环境,所以被是唯一官方支持的IDE。除非资深的Eclipse 或Sublime开发者,否则一般不推荐使用Eclipse或Sublime进行二次开发。硬件底层开发可以在 Eclipse project 和 a Sublime project 找到源码。
{% raw %}
To view this video please enable JavaScript, and consider upgrading to a web browser that
supports HTML5 video
{% endraw %}
Qt Creator 功能
Qt creator 提供单击选择变量、代码自动补全、代码编译和固件上传等功能。
Linux 平台的 Qt Creator
在启动Qt creator之前, 需要先创建工程文件 :
cd ~/src/Firmware
mkdir ../Firmware-build
cd ../Firmware-build
cmake ../Firmware -G "CodeBlocks - Unix Makefiles" -DCONFIG=nuttx_px4fmu-v2_default
接着启动Qt creator(如果系统没安装Qt Creator 百度一下linux下安装Qt Creator,然后再启动Qt Creator)并加载 Firmware 根目录下 CMakeLists.txt 文件,步骤:点击工具栏 File -> Open File or Project -> Select the CMakeLists.txt file 。
如果加载提示ninja没有安装,请按照“高级Linux”章节进行ninja编译工具的安装,安装完成后,log out(登出)并log in(登入)。
加载了文件后,点击左侧projects按钮,在run onfiguration栏选择’custom executable’,在executable 栏里输入’make’, argument栏输入 ‘upload’,将‘play’按钮配置成运行工程。
Windows平台的 Qt Creator
Mac OS 平台的 Qt Creator
启动 Qt Creator 之前,需要先创建 project file :
cd ~/src/Firmware
mkdir build/creator
cd build/creator
cmake .. -G "CodeBlocks - Unix Makefiles"
完成上述步骤以后,启动 Qt Creator, 完成下面视频中的步骤,就可以进行工程文件的编译了。
{% raw %}
To view this video please enable JavaScript, and consider upgrading to a web browser that
supports HTML5 video
{% endraw %}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论