Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: adapt to qt6 for PlatformWindowHelper #281

Merged
merged 1 commit into from
Mar 19, 2025

Conversation

18202781743
Copy link
Contributor

Timer maybe miss killed.
MouseEvent conversion is wrong in qt6, old way will be called
recursively.
requestActivateWindow is called recurisvely in qt6.

pms: TASK-368399

Timer maybe miss killed.
MouseEvent conversion is wrong in qt6, old way will be called
recursively.
requestActivateWindow is called recurisvely in qt6.

pms: TASK-368399
@18202781743 18202781743 requested review from mhduiy and BLumia March 13, 2025 12:15
deepin-ci-robot added a commit to linuxdeepin/qt6platform-plugins that referenced this pull request Mar 13, 2025
Synchronize source files from linuxdeepin/qt5platform-plugins.

Source-pull-request: linuxdeepin/qt5platform-plugins#281
@deepin-ci-robot
Copy link
Contributor

deepin pr auto review

代码审查意见:

  1. DFrameWindow::updateShadow函数中,添加了killTimer来确保定时器不会在频繁调用updateShadow时被遗漏。这是一个好的做法,可以避免定时器累积。

  2. DPlatformWindowHelper::eventFilter函数中,对于QEvent的处理,添加了对points是否为空的检查。这是一个好的做法,可以避免在points为空时尝试访问points[0]导致的崩溃。

  3. DPlatformWindowHelper::eventFilter函数中,对于QEvent的处理,直接修改了esource属性。这可能会影响其他使用e的地方,应该确保这种修改不会导致其他问题。

  4. DPlatformWindowHelper::eventFilter函数中,对于QEvent的处理,使用了QMutableEventPoint::update来更新targetPoint。这是一个好的做法,可以确保targetPoint的属性与point一致。

  5. DPlatformWindowHelper::eventFilter函数中,对于QEvent的处理,直接调用了m_frameWindow->mouseMoveEvent(e)。这可能会覆盖其他处理mouseMoveEvent的逻辑,应该确保这种修改不会导致其他问题。

  6. DPlatformWindowHelper::eventFilter函数中,对于QEvent的处理,使用了qApp->sendEvent来发送事件。这是一个好的做法,可以确保事件被正确地发送和处理。

  7. DPlatformWindowHelper::eventFilter函数中,对于QEvent的处理,使用了QEventPoint::withTimeStamp来创建新的QEventPoint。这是一个好的做法,可以确保新的QEventPoint具有正确的属性。

  8. DPlatformWindowHelper::eventFilter函数中,对于QEvent的处理,使用了QEventPoint::update来更新targetPoint。这是一个好的做法,可以确保targetPoint的属性与point一致。

  9. DPlatformWindowHelper::eventFilter函数中,对于QEvent的处理,使用了e->m_source = Qt::MouseEventSynthesizedByQt来设置source属性。这是一个好的做法,可以确保source属性被正确地设置。

  10. DPlatformWindowHelper::eventFilter函数中,对于QEvent的处理,使用了m_frameWindow->mouseMoveEvent(e)来处理事件。这是一个好的做法,可以确保事件被正确地处理。

总体来说,代码的修改是合理的,但是需要注意确保修改不会导致其他问题。

@deepin-ci-robot
Copy link
Contributor

[APPROVALNOTIFIER] This PR is NOT APPROVED

This pull-request has been approved by: 18202781743, BLumia

The full list of commands accepted by this bot can be found here.

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@18202781743 18202781743 merged commit 5b741ea into linuxdeepin:master Mar 19, 2025
18 of 20 checks passed
18202781743 pushed a commit to linuxdeepin/qt6platform-plugins that referenced this pull request Mar 19, 2025
Synchronize source files from linuxdeepin/qt5platform-plugins.

Source-pull-request: linuxdeepin/qt5platform-plugins#281
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants