kiran-cpanel-display/0000-fix-revealed-overlapping-temporarily-solve-the-probl-75bfd27c.patch
kylinsecos_admin 613dc180d9 update to 2.2.0
2022-01-20 16:21:42 +08:00

89 lines
4.2 KiB
Diff

From 75bfd27cafae31634a8f93665c325530bdb7d3a6 Mon Sep 17 00:00:00 2001
From: liuxinhao <liuxinhao@kylinos.com.cn>
Date: Mon, 6 Dec 2021 16:48:08 +0800
Subject: [PATCH 0/1] fix(revealed overlapping): temporarily solve the problem
of display overlap and screen gap(#46434)
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
- 暂时解决屏幕分辨率调节时因未同步调整其他屏幕的位置导致的显示重叠与屏幕存在间隙的问题
Closes #46434
---
src/kiran-display-configuration.cpp | 49 ++++++++++++++++-------------
1 file changed, 28 insertions(+), 21 deletions(-)
diff --git a/src/kiran-display-configuration.cpp b/src/kiran-display-configuration.cpp
index bb88705..0b6016d 100644
--- a/src/kiran-display-configuration.cpp
+++ b/src/kiran-display-configuration.cpp
@@ -94,29 +94,33 @@ void KiranDisplayConfiguration::on_pushButton_extra_ok_clicked()
//添加/更新当前编辑界面的数据
curExtraData2Cache();
- //往屏幕数据中添加剩余的其它数据。
- QVariantMap map = ui->panel->getData();
- QMapIterator<QString, QVariant> i(map);
- while (i.hasNext()) {
- i.next();
- QVariantMap d = i.value().toMap();
- if(m_extraData.contains(i.key()))//两个map的key值匹配上。
- {
- QVariantMap extraMap = m_extraData.value(i.key());
- //添加
- d.insert("primary", m_primaryMonitorName==d.value("name").toString());
- d.insert("enabled", extraMap.value("enabled"));
- d.insert("resolving", extraMap.value("resolving"));
- d.insert("refreshRate", extraMap.value("refreshRate"));
+ ///FIXME:此处保存两次只是为了暂时解决修改分辨率时由于未进行屏幕排列导致的内容重叠以及屏幕之中存在间隔
+ ///后续重构应该更改为下方参数修改时上方预览应同步修改,以及动态调整屏幕位置
+ for( int i=0;i<2;i++ )
+ {
+ //往屏幕数据中添加剩余的其它数据。
+ QVariantMap map = ui->panel->getData();
+ QMapIterator<QString, QVariant> iter(map);
+ while (iter.hasNext()) {
+ iter.next();
+ QVariantMap d = iter.value().toMap();
+ if(m_extraData.contains(iter.key()))//两个map的key值匹配上。
+ {
+ QVariantMap extraMap = m_extraData.value(iter.key());
+ //添加
+ d.insert("primary", m_primaryMonitorName==d.value("name").toString());
+ d.insert("enabled", extraMap.value("enabled"));
+ d.insert("resolving", extraMap.value("resolving"));
+ d.insert("refreshRate", extraMap.value("refreshRate"));
+ }
+ setMonitorProperty(iter.key(), d);
}
-
- setMonitorProperty(i.key(), d);
+ //缩放率所有屏幕都是通用的。
+ Display("SetWindowScalingFactor", QVariantList() << ui->comboBox_extra_windowScalingFactor->currentIndex());
+ Display("ApplyChanges");
+ //可能设置失败,界面根据设置实际情况再刷新。
+ refreshWidget();
}
- //缩放率所有屏幕都是通用的。
- Display("SetWindowScalingFactor", QVariantList() << ui->comboBox_extra_windowScalingFactor->currentIndex());
- Display("ApplyChanges");
- //可能设置失败,界面根据设置实际情况再刷新。
- refreshWidget();
showMessageBox();
m_dbusPropertiesChangedBlock = false;
@@ -611,6 +615,9 @@ void KiranDisplayConfiguration::setMonitorProperty(const QString &monitorPath, c
if(map.contains("enabled")) Monitor<QVariant>(monitorPath, "Enable", QVariantList() << map.value("enabled").toBool());
if(map.contains("x") && map.contains("y")) Monitor<QVariant>(monitorPath, "SetPosition", QVariantList() << (int32_t)map.value("x").toInt() << (int32_t)map.value("y").toInt());
+ if(map.contains("x") && map.contains("y")){
+ qInfo() << "set position:" << (int32_t)map.value("x").toInt() << (int32_t)map.value("y").toInt();
+ }
if(map.contains("rotation")){
QVariant var;
var.setValue(QDBusArgument() << (ushort)map.value("rotation").toUInt());
--
2.27.0