当前位置: 首页 > news >正文

Treeland 技术揭秘,如何使得 DDE 纵享丝滑?

近日,deepin(深度)社区亮相COSCon'24 第九届中国开源年会开源市集,且社区资深桌面研发工程师张丁元为大家来了《Treeland,DDE进步的阶梯》技术分享。

就着这个机会,今天就让我们一起来聊聊如何在追求华丽动画和流畅体验的同时,还能保持系统的轻盈和高效。这就像是在玩一场平衡游戏,设计师和架构师各自站在天平的两端,一边是视觉盛宴,另一边是性能怪兽。这两者之间的平衡,就需要我们研发团队来巧妙地“牺牲”一些头发(脑力)来实现了。

历史背景

在 deepin 15 时期,开发团队使用 Mutter 为高性能设备提供流畅图形效果,用 Metacity 为低配置设备保证系统流畅性。但在 deepin 20 时期,团队决定采用 KWin 作为新窗口管理器,因其具备强大功能且可关闭合成器,适应不同硬件配置。因此,放弃了 Mullter+Metacity 的组合,以确保在各种设备上提供流畅安全的图形界面体验。然而,技术的不断发展促使我们再次面临技术革新。

技术选择:X11 与 Wayland

在 Linux 下目前有两个技术栈,一个是历史悠久的 X11,另一个是较新的 Wayland 。接下来,跟随我一起来对比两个技术。

X11Wayland
架构传统的客户端-服务器模型,支持网络传输和远程显示简化设计,去除×服务器复杂性,提高效率和响应速度,专注于本地显示
性能由于设计老旧,性能在现代场景下不
佳,依赖扩展和补丁实现现代图形效
现代化设计,简化染过程,性能提升显著,尤其在动画和窗口操作方面
安全性安全性问题明显,应用程序可以访问
彼此的窗口信息,易受恶意程序干扰
应用程序隔离性强,无法访问其他程序的图像或输入输出,安全性高
可扩展性和兼容性x11有非常广泛的应用支持和兼容性。
许多老的应用程序和桌面环境仍然依赖于X11协议
逐渐被主流桌面环境支持,但生态不如x11广泛,需要兼容层运行×11应用
输入设备支持对传统输入设备支持成熟,但在多点
触控和手势支持方面不够灵活
优化现代硬件支持,特别是在多点触控和手势方面
远程桌面和网络透明性支持通过网络远程传输显示内容,适
合专业领域使用
没有×11的网络透明性,远程桌面功能有限,通常需要第三方工具

总的来说,X11 作为老牌的显示服务器,拥有广泛的兼容性和成熟的生态系统。然而,其架构在安全性、性能和易用性方面存在一些局限性。相比之下,Wayland 作为一种新兴的显示服务器,其架构简化了客户端和服务器之间的通信过程,减少了潜在的安全漏洞,从而提高了整体的安全性。

此外,Wayland 在性能方面也有显著的优势,能够更好地支持现代显示技术,如高分辨率和高帧率的显示任务。最后,Wayland 的架构设计使得其配置和管理相对简单,用户体验更加友好,有助于吸引更多新手用户。

架构设计与新窗口管理器 Treeland

从技术层面上,我们认为是时候更新技术方案了,曾经的 X11 + 窗口管理器 + 合成器的模式,灵活但不满足需求,而 Wayland 可通过将窗口管理器、合成器与显示系统从底层整合,提供了一种避免画面撕裂的更新机制。

因此 DDE 决定结合 Wayland 开发一个新的窗口管理器——Treeland。它在底层使用 wlroots 作为 Wayland 基础库,不修改 wlroots 代码,可随时同步上游进度,获得新的功能和修复。上层使用 Qt,使技术栈更统一。它专为满足 DDE 需求而设计,避免了使用第三方窗口管理器时常见的破坏性调整、同步问题和维护成本。

上图描述了 Treeland 在整体上会使用哪些项目或接口完成功能。

Treeland 结构图

Treeland 的技术结构与功能

1、重要项目介绍

  • QWlroots:wlroots 的 Qt 绑定,将 Wayland 信号转换为 Qt 风格信号。

  • Waylib:将 wlroots 组件封装成 QtQuick 对象,使用 QPA 为 Treeland 提供事件转换与分发。

  • DtkDeclarative:DTK 的 QtQuick 组件,封装大部分 DTK style 控件。

在 Waylib 中,QPA 功能举足轻重。系统底层事件先进入 Waylib,转换为 Qt 内部事件发送给上层。当用户点击窗口时,Treeland 通过 Waylib 生成事件发送给客户端,完成界面交互。

Treeland 处理底层事件与上层事件的流程

2、界面效果与优化

  • 圆角:

DDE 及 deepin 社区应用大量采用窗口圆角设计,Treeland 提供自己的裁圆角控件,新造型算法减少几何顶点数量和计算量,采用新抗锯齿算法提高 GPU 性能。QtQuick 圆角是由 Rectangle 组件提供的,它只能同时对四个角进行操作(红色块)。但 DTK 程序具备异形窗口的能力,所以 Treeland 提供了自己的裁圆角控件(黄色块)。

新的造型算法、几何顶点数量比 QtQuick 原生的 Rectangle 减少50%,GPU 顶点渲染和三角细分性能提升100%。

采用新的抗锯齿算法,提高了 GPU 片元着色器性能,相比于普通 4xMSAA 抗锯齿算法,计算量减少1/4。

红色为 QtQuick 圆角/黄色为 Treeland 圆角

  • 模糊:

QtQuick 的模糊组件仅支持对控件自身进行模糊,这并不符合 Treeland 的需求。Treeland 重新实现模糊组件,能从显存获取组件下方图像数据,使用融合模糊算法优化性能。

QtQuick 模糊控件

Treeland 模糊控件

  • 阴影:

Treeland 使用 BorderImage 作为窗口阴影贴图,通过 ImageProvider 手动创建贴图材质,在相同大小下可复用同一份材质。

  • 动画:

直接使用 QtQuick 提供的动画组件为界面提供动画效果。使用 State 和 Transition 为组件定义属性变化,例如窗口最大化和还原,两个 State 切换会触发不同的 Transition 执行属性变化,在属性变化时,使用 QtQuick 的动画组件完成动画播放。

3、多用户功能

Treeland 作为解决方案的一部分,旨在实现多用户共用合成器。与传统模式相比,DDM 和 Treeland 重新设计工作流程,将 Treeland 单独抽离,用户通过相同机制将窗口画面发送给 Treeland 进行合成上屏,节省内存,避免黑屏闪烁和状态同步难题。

一个简化的 DDM 与 Treeland 的多用户登录流程

4、与 systemd 的集成

DDE 的每个用户会话切换至 systemd 服务,Treeland 模式下加载单独服务为用户会话注入显示环境变量,使用 systemd 的 socket 机制懒加载,确保用户侧窗口正常显示。

多用户登录时的基本流程

总结

深度操作系统(DDE)在窗口管理器方面的演进,从 Mutter 和 Metacity ,到 KWin ,再到我们自己的 Treeland ,展示了我们在系统架构和用户体验方面的持续创新和改进。

相关阅读:

(1)deepin - 国际排名查看

(2)深度桌面环境(DDE)

(3)deepin 2024 年度用户使用体验调研

相关文章:

Treeland 技术揭秘,如何使得 DDE 纵享丝滑?

近日,deepin(深度)社区亮相COSCon24 第九届中国开源年会开源市集,且社区资深桌面研发工程师张丁元为大家来了《Treeland,DDE进步的阶梯》技术分享。 就着这个机会,今天就让我们一起来聊聊如何在追求华丽动…...

快速了解SpringBoot 统一功能处理

拦截器 什么是拦截器: 拦截器是Spring框架提供的重要功能之一,主要进行拦截用户请求,在指定方法前后,根据业务需求,执行预先设定的代码。 也就是说,允许开发⼈员提前预定义⼀些逻辑,在⽤⼾的请求响应前后执⾏.也可以…...

C++区分数组的引用和引用的数组

void f(int (&arr)[10]) {//正确} void f1(int &arr[10]) {//不允许使用引用的数组} [](数组下标运算符)的优先级高于&(取地址运算符)。所有表达式&arr[i]等价于&(arr[i]) 引用的数组 一个包含引用的数组&…...

【harbor】离线安装2.9.0-arm64架构服务制作和升级部署

harbor官网地址:Harbor 参考文档可以看这里:部署 harbor 2.10.1 arm64 - 简书。 前提环境准备: 安装docker 和 docker-compose 先拉arm64架构的harbor相关镜像 docker pull --platformlinux/arm64 ghcr.io/octohelm/harbor/harbor-regist…...

ESLint 使用教程(五):ESLint 和 Prettier 的结合使用与冲突解决

前言 在现代前端开发中,代码质量与代码风格的统一是两个非常重要的方面。良好的代码质量能减少 bug 的产生,而统一的代码风格则能提高团队协作的效率。为了实现这两个目标,我们通常会使用一些工具。 为了保证代码的可读性和维护性&#xff0…...

uniApp之uni-file-picker使用踩坑

标题党~也不算坑吧 就是初体验 上传是需要存储一下子的,我以为uniApp是自己免费开的服务给大家中转使用,就没管这个事,但是官网是这么说的: 就我是怎么发现的,使用了一段时间后,上传的图片都裂了&#xff…...

【C语言】。末尼

用js写一个冒泡排序 当然可以。在JavaScript中&#xff0c;你可以使用递归的方式来实现冒泡排序算法。这是一个简单的示例&#xff1a; function bubbleSort(arr) { let len arr.length; if(len < 1){ return arr; // 如果数组只有一个元素或为空&#xf…...

【鉴权】深入解析 Token:身份认证的核心技术

目录 引言一、Token 的定义与概念1.1 Token 是什么&#xff1f;1.2 无状态性与自包含性1.3 Token 的工作流程1.3.1 基本工作流程1.3.2 工作流程图示 二、Token 的常见用途2.1 用户身份验证2.2 授权控制2.3 防止跨站请求伪造&#xff08;CSRF&#xff09;2.4 跨域认证 三、Token…...

FastReport将停止 .NET Framework 上的 WebReport 更新

从2024/ 12 /1 日起&#xff0c;Fastreport将停止发布更新和提供对 FastReport.Web (.NET Framework) 的技术支持。该库一直是使用 Online Designer 的许多项目中报告的核心。这些更改意味着 FastReport.Web (Legacy) 库&#xff08;FastReport.Net包的一部分&#xff09;将不再…...

面试:TCP、UDP如何解决丢包问题

文章目录 一、TCP丢包原因、解决办法1.1 TCP为什么会丢包1.2 TCP传输协议如何解决丢包问题1.3 其他丢包情况&#xff08;拓展&#xff09;1.4 补充1.4.1 TCP端口号1.4.2 多个TCP请求的逻辑1.4.3 处理大量TCP连接请求的方法1.4.4 总结 二、UDP丢包2.1 UDP协议2.1.1 UDP简介2.1.2…...

在Ubuntu下安装RabbitMQ、添加一个新的登录用户并设置密码

在Ubuntu下安装RabbitMQ、添加一个新的登录用户并设置密码 在Ubuntu下安装RabbitMQ可以按照以下步骤进行&#xff1a;步骤 1: 更新系统步骤 2: 安装Erlang步骤 3: 添加RabbitMQ仓库步骤 4: 更新APT索引并安装RabbitMQ步骤 5: 启动RabbitMQ服务步骤 6: 检查RabbitMQ状态步骤 7: …...

HTTPS通信和TCP通信有什么不一样

HTTPS通信和TCP通信的主要区别如下&#xff1a; ‌协议层次‌&#xff1a;HTTPS是应用层协议&#xff0c;建立在HTTP协议之上&#xff0c;并增加了SSL/TLS加密层&#xff1b;而TCP是传输层协议&#xff0c;提供可靠的数据传输服务。‌安全性‌&#xff1a;HTTPS通过SSL/TLS加密…...

Kafka 的一些问题,夺命15连问

kafka-中的组成员 kafka四大核心 生产者API 允许应用程序发布记录流至一个或者多个kafka的主题&#xff08;topics&#xff09;。 消费者API 允许应用程序订阅一个或者多个主题&#xff0c;并处理这些主题接收到的记录流 StreamsAPI 允许应用程序充当流处理器&#xff08;s…...

unity3d————延时函数

1.public void InvokeRepeating(string methodName, float time, float repeatRate); 延迟重复执行函数 InvokeRepeating 参数一&#xff1a;函数名字符串 参数二&#xff1a;第一次执行的延迟时间 参数三&#xff1a;之后每次执行的间隔时间 注意&#xff1a; 1-1.延时函数第…...

计算机学生自我提升方法——善用搜索引擎

计算机学生自我提升方法——善用搜索引擎 在信息爆炸的时代&#xff0c;计算机专业的学生如何有效地自我提升&#xff1f;答案可能就藏在一个简单却强大的工具——搜索引擎中。搜索引擎不仅是获取知识的入口&#xff0c;更是解决问题的利器。下面&#xff0c;我将分享一些善用…...

游戏引擎学习第一天

视频参考: https://www.bilibili.com/video/BV1zGDCYHErA/ 创建一个保存项目的路径 VS的安装略过&#xff0c;个人自行百度 1. vs 创建第一个CMAKE的窗口项目 game.cpp 修改如下的代码 到https://learn.microsoft.com/en-us/windows/win32/api/winbase/nf-winbase-winmain 去…...

uni-app view循环绑定click和 v-if

<view class"layout-wrap-item" v-for"(item, index) in menuItems" :key"index" click"item.clickHandler" :v-if"showMenu(item)"></view> const xxx (id) > { }; // 定义菜单项数组 const menuItems …...

Redis 高并发分布式锁实战

目录 环境准备 一 . Redis 安装 二&#xff1a;Spring boot 项目准备 三&#xff1a;nginx 安装 四&#xff1a;Jmeter 下载和配置 案例实战 优化一&#xff1a;加 synchronized 锁 优化二&#xff1a;使用 redis 的 setnx 实现分布式锁 优化三&#xff1a;使用 Lua 脚本…...

关于elementui el-radio 赋值问题

今天遇到这样的问题&#xff1a; 点击的时候&#xff0c;同时选中 照抄官网&#xff01; 后来发现了问题&#xff1a; 也就是说如果你的版本太低&#xff0c;就不能用value&#xff0c;而得用label&#xff0c;于是修改 <el-radio-group v-model"searchTime"&g…...

2024-11-6----Android 11(全志713m)----- 关于添加 Selinux 权限

需求 节点: /sys/devices/platform/motor0/motor_ctrl上层 APP 使用 JNI 需要对该节点进行 echo 的操作,操作失败。 添加前的验证工作 adb 进去验证下,如下图所示: 发现权限不够。su 以后再操作是OK的,如下图: 添加前的修改 为防止报权限错误,直接给777,因为该…...

论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(二)

HoST框架核心实现方法详解 - 论文深度解读(第二部分) 《Learning Humanoid Standing-up Control across Diverse Postures》 系列文章: 论文深度解读 + 算法与代码分析(二) 作者机构: 上海AI Lab, 上海交通大学, 香港大学, 浙江大学, 香港中文大学 论文主题: 人形机器人…...

Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例

使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件&#xff0c;常用于在两个集合之间进行数据转移&#xff0c;如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model&#xff1a;绑定右侧列表的值&…...

3.3.1_1 检错编码(奇偶校验码)

从这节课开始&#xff0c;我们会探讨数据链路层的差错控制功能&#xff0c;差错控制功能的主要目标是要发现并且解决一个帧内部的位错误&#xff0c;我们需要使用特殊的编码技术去发现帧内部的位错误&#xff0c;当我们发现位错误之后&#xff0c;通常来说有两种解决方案。第一…...

在四层代理中还原真实客户端ngx_stream_realip_module

一、模块原理与价值 PROXY Protocol 回溯 第三方负载均衡&#xff08;如 HAProxy、AWS NLB、阿里 SLB&#xff09;发起上游连接时&#xff0c;将真实客户端 IP/Port 写入 PROXY Protocol v1/v2 头。Stream 层接收到头部后&#xff0c;ngx_stream_realip_module 从中提取原始信息…...

大模型多显卡多服务器并行计算方法与实践指南

一、分布式训练概述 大规模语言模型的训练通常需要分布式计算技术,以解决单机资源不足的问题。分布式训练主要分为两种模式: 数据并行:将数据分片到不同设备,每个设备拥有完整的模型副本 模型并行:将模型分割到不同设备,每个设备处理部分模型计算 现代大模型训练通常结合…...

JDK 17 新特性

#JDK 17 新特性 /**************** 文本块 *****************/ python/scala中早就支持&#xff0c;不稀奇 String json “”" { “name”: “Java”, “version”: 17 } “”"; /**************** Switch 语句 -> 表达式 *****************/ 挺好的&#xff…...

dify打造数据可视化图表

一、概述 在日常工作和学习中&#xff0c;我们经常需要和数据打交道。无论是分析报告、项目展示&#xff0c;还是简单的数据洞察&#xff0c;一个清晰直观的图表&#xff0c;往往能胜过千言万语。 一款能让数据可视化变得超级简单的 MCP Server&#xff0c;由蚂蚁集团 AntV 团队…...

ip子接口配置及删除

配置永久生效的子接口&#xff0c;2个IP 都可以登录你这一台服务器。重启不失效。 永久的 [应用] vi /etc/sysconfig/network-scripts/ifcfg-eth0修改文件内内容 TYPE"Ethernet" BOOTPROTO"none" NAME"eth0" DEVICE"eth0" ONBOOT&q…...

2025季度云服务器排行榜

在全球云服务器市场&#xff0c;各厂商的排名和地位并非一成不变&#xff0c;而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势&#xff0c;对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析&#xff1a; 一、全球“三巨头”…...

Docker 本地安装 mysql 数据库

Docker: Accelerated Container Application Development 下载对应操作系统版本的 docker &#xff1b;并安装。 基础操作不再赘述。 打开 macOS 终端&#xff0c;开始 docker 安装mysql之旅 第一步 docker search mysql 》〉docker search mysql NAME DE…...