Linux(33)Rockchip RK3568 Ubuntu22.04上通过SSH运行Qt程序和关闭Chrome的密钥提示

简介: Linux(33)Rockchip RK3568 Ubuntu22.04上通过SSH运行Qt程序和关闭Chrome的密钥提示

嵌入式系统中运行Qt程序通常需要一些特别的配置,尤其是在没有标准图形环境的情况下。本文将详细介绍如何在Rockchip RK3568平台上配置和运行Qt程序,以及如何解决一些常见的问题。

ssh/adb 运行界面应用不需要x11转发

使用Linux Framebuffer (fbdev)

Qt可以配置为使用Linux Framebuffer作为后端来显示界面。这不需要X11支持,但可能不支持Qt的一些高级功能。要使用Framebuffer,可以设置环境变量:

export QT_QPA_PLATFORM=linuxfb
使用EGLFS

EGLFS是一个适用于嵌入式系统的Qt平台插件,它使用OpenGL ES来渲染图形界面。要使用EGLFS,可以设置环境变量:

export QT_QPA_PLATFORM=eglfs
使用Wayland

如果RK3568系统上安装了Wayland,并且Qt支持Wayland,可以使用Wayland作为显示后端。设置环境变量:

export QT_QPA_PLATFORM=wayland
Qt平台插件参数

QT_QPA_PLATFORM环境变量支持多种参数,包括:

  • linuxfb: 使用Linux Framebuffer。
  • eglfs: 使用EGL Full Screen。
  • wayland: 使用Wayland。
  • xcb: 使用X Window System。
  • minimal: 最小化后端。
  • offscreen: 无显示后端。
  • vnc: 通过VNC协议远程显示。
Qt程序无法连接到X服务器

最终解决办法:

如果Qt程序无法连接到X11服务器,需要设置DISPLAY环境变量,并检查X权限和服务器状态:

export DISPLAY=:0
export QT_QPA_PLATFORM=linuxfb
# 这样adb 和 ssh都可以执行qt程序,饼显示到display 桌面上。
# xhost +SI:localuser:<root>
OpenGL驱动问题

如果遇到OpenGL驱动问题,可以尝试禁用OpenGL加速或配置Qt使用OpenGL ES驱动:

export QT_OPENGL=software

关闭Google Chrome的密钥环密码提示

要关闭Google Chrome的新密钥环密码提示,可以修改Chrome的启动配置文件:

sudo vi/usr/share/applications/google-chrome.desktop

在文件中添加--password-store=basic到Chrome的启动命令:

Exec=/usr/bin/google-chrome-stable --password-store=basic %U

完整的/usr/share/applications/google-chrome.desktop

echo "[Desktop Entry]
Version=1.0
Name=Google Chrome
Exec=/usr/bin/google-chrome-stable --password-store=basic --homepage www.baidu.com %U
Terminal=false
X-MultipleArgs=false
Type=Application
Icon=google-chrome
Categories=Network;WebBrowser;
MimeType=text/html;text/xml;application/xhtml_xml;image/webp;x-scheme-handler/http;x-scheme-handler/https;x-scheme-handler/ftp;
Actions=new-window;new-private-window;
[Desktop Action new-window]
Name=New Window
Exec=/usr/bin/google-chrome-stable --password-store=basic --homepage www.baidu.com
TargetEnvironment=Unity
[Desktop Action new-private-window]
Name=New Incognito Window
Exec=/usr/bin/google-chrome-stable --password-store=basic --incognito --homepage www.baidu.com
TargetEnvironment=Unity" |  tee /usr/share/applications/google-chrome.desktop

这将使Chrome的密码存储方式更改为基本模式,不再提示输入新密钥环密码。

总结

在嵌入式系统中ssh/adb 运行Qt程序可能需要一些额外的步骤和调试。本文提供了一些常见问题的解决方案,Linux平台上顺利运行Qt程序。


相关文章
|
14天前
|
存储 Ubuntu 自动驾驶
运行Udacity的MPC控制项目指南(project_10)在Ubuntu 18.04环境下
以上步骤应该能够帮助您成功设置并运行Udacity MPC控制项目,在此过程中您将学习如何应用模型预测控制理论去指导车辆沿着轨迹自主驾驶,在模拟环境下测试其效果。这个过程不但涵盖了理论知识也有实践操作,对于学习自动驾驶车辆控制系统非常有帮助。
73 15
|
4月前
|
Ubuntu 定位技术 TensorFlow
源码编译安装ROCm以运行tensorflow-rocm(适用于Ubuntu 23.04)
总结一番,完成这趟奇妙的技术之旅后,乐趣多多,还能享受 tensorflow-rocm 带来的便利和速度。这趟旅程需要耐心,勇气,以及对技术的热爱。朋友,做好准备,让你的Ubuntu系统展翅高飞吧!
188 9
|
5月前
|
Ubuntu 安全
Ubuntu中遇到"无法创建临时文件"/tmp/..."在普通或root用户运行apt-get update时的错误解决办法
这些步骤当然不能涵盖所有可能出现问题的场合,但是能覆盖大多数常见的情景。希望这些信息能帮到你解决"无法创建临时文件"/tmp/..."这样的问题。不过,请记住,因为修改系统文件和目录的权限,清理临时文件,或者运行磁盘检查,都可能对系统造成影响,所以执行这些操作前要先确认这是安全的,必要时最好先做好数据备份。
264 10
|
6月前
|
Ubuntu Linux 网络安全
Ubuntu Docker镜像:支持systemctl、SSH、VNC
总的来说,创建一个支持systemctl、SSH和VNC的Ubuntu Docker镜像需要一些技术知识,但是通过学习和实践,我们可以掌握这些技术。这将使我们能够更有效地使用Docker,更好地管理我们的应用程序和服务。CentOS系统中的日志文件位置和管理
186 17
|
6月前
|
Ubuntu 安全 网络安全
Docker镜像:Ubuntu支持systemctl、SSH和VNC
总的来说,Docker提供了一个灵活且强大的方式来创建和运行自定义的Ubuntu镜像。通过理解和使用Dockerfile,你可以轻松地创建一个支持systemctl、SSH和VNC的Ubuntu镜像。
361 21
|
7月前
|
监控 安全 Ubuntu
Ubuntu(22.04)云主机SSH安全加固
通过上述步骤,你可以有效地加固Ubuntu 22.04云主机的SSH安全性。这些措施不仅能防止常见的攻击,还能提升整体服务器的安全性和稳定性。建议在实施这些安全加固措施后,定期检查系统日志和更新安全策略,以应对不断变化的安全威胁。
355 14
|
7月前
|
监控 Ubuntu Linux
ubuntu中设置开机自动运行的(sudo)指令
通过合理选择和配置上述方法,您可以确保在系统启动时自动执行所需的命令,并具备sudo权限,从而提高系统自动化管理的能力。
932 8
|
7月前
|
安全 Linux 网络安全
CentOS 8下SSH连接超时与“无法加载主机密钥”错误的排查与修复
在CentOS 8系统中,宝塔面板提示“出错了,面板运行时发生错误”,导致插件无法正常显示。同时,SSH连接超时,修复面板功能失效。通过VNC连接排查,发现SSH服务安装和配置问题频发,最终通过重装SSH、调整权限并重新生成主机密钥文件解决问题,成功恢复SSH连接。
427 16
|
Ubuntu Shell 网络安全
安装了ubuntu虚拟机后发现shell无法连接 ubuntu开启ssh连接
【8月更文挑战第23天】安装了ubuntu虚拟机后发现shell无法连接
1111 6
|
10月前
|
监控 Ubuntu 安全
debian或Ubuntu中开启ssh允许root远程ssh登录的方法
在Debian或Ubuntu系统中启用root用户的SSH远程登录需要编辑SSH配置文件、设置root密码并重启SSH服务。虽然这可以在某些情况下提供便利,但必须注意安全性,通过使用强密码、限制IP访问、使用SSH密钥认证等方法来保护服务器的安全。
3978 5