4#include <render/qohosview.h>
6#include <QtCore/private/qnapi_p.h>
7#include <QtCore/private/qohoscommon_p.h>
8#include <QtCore/qscopeguard.h>
9#include <QtGui/private/qguiapplication_p.h>
10#include <QtGui/private/qhighdpiscaling_p.h>
11#include <QtGui/private/qwindow_p.h>
12#include <QtGui/qbitmap.h>
13#include <QtGui/qpalette.h>
14#include <ace/xcomponent/native_interface_xcomponent.h>
15#include <arkui/native_type.h>
18#include <qarkui/window.h>
19#include <qohosdeviceinfo_p.h>
20#include <qohosinputmethodeventhandler.h>
21#include <qohosjsmain.h>
22#include <qohosplatformbackingstore.h>
23#include <qohosplatformintegration.h>
24#include <qohosplatformscreen.h>
25#include <qohosplatformwindow.h>
26#include <qohosutils.h>
27#include <qpa/qplatformscreen.h>
28#include <qpa/qplatformtheme.h>
29#include <qpa/qwindowsysteminterface.h>
30#include <render/qnativenode.h>
31#include <render/qohoswindowproxy.h>
32#include <render/qwindowproxyregistry.h>
58 Qt::WindowModality windowModality)
62 switch (windowModality) {
63 case Qt::WindowModality::NonModal:
65 case Qt::WindowModality::WindowModal:
67 case Qt::WindowModality::ApplicationModal:
72 "%s: got illegal Qt::WindowModality value (%d), using the default instead",
73 Q_FUNC_INFO,
static_cast<
int>(windowModality));
78template<
typename ...SignalParams>
80 QPointer<QOhosView> viewPtr,
std::function<
bool(
QOhosView &)> predicate,
void (QOhosView::*signalFuncPtr)(SignalParams ...))
82 return [signalFuncPtr, viewPtr, predicate = std::move(predicate)](SignalParams ...args) {
83 if (viewPtr && predicate(*viewPtr))
84 Q_EMIT (*viewPtr.*signalFuncPtr)(args...);
94 explicit AvoidAreaCache(std::function<AvoidArea(AvoidAreaType)> avoidAreasProvider);
98 const AvoidArea &avoidArea);
103 std::function<AvoidArea(AvoidAreaType)> m_avoidAreasProvider;
104 QMap<AvoidAreaType, AvoidArea> m_store;
114 QOhosWindowProxy::
AvoidAreaType avoidAreaType,
const QOhosWindowProxy::AvoidArea &avoidArea)
116 m_store[avoidAreaType] = avoidArea;
122 if (m_store.contains(avoidAreaType))
123 return m_store.value(avoidAreaType);
125 auto result = m_avoidAreasProvider(avoidAreaType);
126 m_store[avoidAreaType] = result;
132 if (!avoidArea.visible)
135 marginsToUpdate.setTop(qMax(marginsToUpdate.top(), avoidArea.topRect.height()));
136 marginsToUpdate.setLeft(qMax(marginsToUpdate.left(), avoidArea.leftRect.width()));
137 marginsToUpdate.setRight(qMax(marginsToUpdate.right(), avoidArea.rightRect.width()));
138 marginsToUpdate.setBottom(qMax(marginsToUpdate.bottom(), avoidArea.bottomRect.height()));
142 const QPoint &geometryOrigin,
const QRect &frameGeometry)
144 int topFrameMargin = qAbs(frameGeometry.top() - geometryOrigin.y());
145 int sideAndBottomFrameMargin = qAbs(frameGeometry.left() - geometryOrigin.x());
148 frameGeometry.width() - 2 * sideAndBottomFrameMargin,
149 frameGeometry.height() - topFrameMargin - sideAndBottomFrameMargin
155 QRect newGeometry = geometry;
156 if (newGeometry.top() < availableArea.top())
157 newGeometry.moveTop(availableArea.top());
158 if (newGeometry.bottom() > availableArea.top() + availableArea.height())
159 newGeometry.moveBottom(availableArea.top() + availableArea.height());
160 if (newGeometry.left() < availableArea.left())
161 newGeometry.moveLeft(availableArea.left());
162 if (newGeometry.right() > availableArea.right())
163 newGeometry.moveRight(availableArea.right());
169 const QRect &geometry,
const QRect &availableArea,
const QRect &screenGeometry)
171 QRect newGeometry = geometry;
172 constexpr auto minVisibleThresholdSizeFactor = 0.05;
174 const auto minVisibleThresholdInPixelsX = qCeil(screenGeometry.width() * minVisibleThresholdSizeFactor);
175 const auto minVisibleThresholdInPixelsY = qCeil(screenGeometry.height() * minVisibleThresholdSizeFactor);
177 const auto topReachableAreaBoundary = availableArea.top() + minVisibleThresholdInPixelsY;
178 const auto bottomReachableAreaBoundary =
179 availableArea.top() + availableArea.height() - minVisibleThresholdInPixelsY;
180 const auto leftReachableAreaBoundary = availableArea.left() + minVisibleThresholdInPixelsX;
181 const auto rightReachableAreaBoundary = availableArea.right() - minVisibleThresholdInPixelsX;
183 if (newGeometry.bottom() < topReachableAreaBoundary)
184 newGeometry.moveBottom(topReachableAreaBoundary);
185 if (newGeometry.top() > bottomReachableAreaBoundary)
186 newGeometry.moveTop(bottomReachableAreaBoundary);
187 if (newGeometry.right() < leftReachableAreaBoundary)
188 newGeometry.moveRight(leftReachableAreaBoundary);
189 if (newGeometry.left() > rightReachableAreaBoundary)
190 newGeometry.moveLeft(rightReachableAreaBoundary);
197 auto availableArea = targetScreen->availableGeometry();
199 auto *qWindow = platformWindow->window();
200 const auto frameGeometry = QHighDpi::toNativePixels(qWindow->frameGeometry(), targetScreen);
201 auto newGeometry = frameGeometry;
203 auto windowType = qWindow->type();
205 if (windowType == Qt::WindowType::ToolTip)
208 const auto optTransientParentWindowGeometry = qWindow->transientParent() !=
nullptr
210 QOhosPlatformWindow::fromQWindow(qWindow->transientParent())->windowGeometry())
212 if (optTransientParentWindowGeometry == QHighDpi::toNativePixels(qWindow->geometry(), targetScreen))
215 if (!availableArea.isEmpty()) {
216 newGeometry.setSize(newGeometry.size().boundedTo(availableArea.size()));
218 newGeometry = windowType == Qt::WindowType::Popup || windowType == Qt::WindowType::Dialog
219 ? correctFrameGeometryPositionFitToAvailableArea(newGeometry, availableArea)
220 : correctFrameGeometryPositionFitToReachableArea(newGeometry, availableArea, targetScreen->geometry());
222 if (newGeometry.topLeft() != frameGeometry.topLeft()) {
225 "%s: Moving window from: (%d,%d) to: (%d,%d)",
226 Q_FUNC_INFO, frameGeometry.x(), frameGeometry.y(), newGeometry.x(), newGeometry.y());
240 qMax(1, size.width() + margins.left() + margins.right()),
241 qMax(1, size.height() + margins.top() + margins.bottom())};
245 QOhosView::ViewType viewType,
QOhosPlatformWindow *platformWindow, QPlatformScreen *targetScreen)
247 return viewType == QOhosView::ViewType::SubWindow
248 ? tryCorrectFrameGeometry(platformWindow, targetScreen)
249 : platformWindow->windowFrameGeometry();
255 return !visibleWindows.empty()
256 ? visibleWindows.front()
263 return !focusedWindows.empty()
264 ? focusedWindows.front()
270 auto *focusWindow = getFirstTopLevelWindowWithSystemFocusOrNull();
271 auto *firstTopLevelWindow = getFirstTopLevelWindowOrNull();
273 auto isValidSyntheticParent = [&](QWindow *w) {
274 return w !=
nullptr && w != qWindow && w->isVisible();
277 return isValidSyntheticParent(focusWindow)
279 : isValidSyntheticParent(firstTopLevelWindow)
280 ? firstTopLevelWindow
286 using ViewType = QOhosView::ViewType;
288 auto *qWindow = platformWindow->window();
289 auto *parent = qWindow->parent();
290 auto *transientParent = qWindow->transientParent();
292 auto windowType = qWindow->type();
294 QWindow *subWindowTagValue = platformWindow->validSubWindowOfTagValueOrNull();
296 static QSet<Qt::WindowType> fallbackToSubWindowWindowTypes{
304 if (taggedAsMainWindow) {
305 return ViewTypeInfo {
306 .viewType = ViewType::MainWindow,
307 .optLogicalParent =
nullptr,
312 if (taggedAsFloatWindow) {
313 return ViewTypeInfo {
314 .viewType = ViewType::FloatWindow,
315 .optLogicalParent =
nullptr,
319 bool overrideAsSubWindow = subWindowTagValue !=
nullptr;
320 if (overrideAsSubWindow) {
321 return ViewTypeInfo {
322 .viewType = ViewType::SubWindow,
323 .optLogicalParent = subWindowTagValue,
327 if (parent !=
nullptr) {
328 return ViewTypeInfo {
329 .viewType = ViewType::EmbeddedWindow,
330 .optLogicalParent = parent,
334 if (transientParent !=
nullptr) {
335 return ViewTypeInfo {
336 .viewType = ViewType::SubWindow,
337 .optLogicalParent = transientParent,
341 auto *syntheticParent = syntheticParentForQWindowOrNull(platformWindow->window());
343 bool automaticOverrideActive =
344 fallbackToSubWindowWindowTypes.contains(windowType)
345 && syntheticParent !=
nullptr;
346 if (automaticOverrideActive) {
347 return ViewTypeInfo {
348 .viewType = ViewType::SubWindow,
349 .optLogicalParent = syntheticParent,
353 return ViewTypeInfo {
354 .viewType = ViewType::MainWindow,
355 .optLogicalParent =
nullptr,
361 return cursor.bitmap();
366 return cursor.mask();
371 const auto maskTransparentColor = QColor(Qt::color0).rgba();
372 const auto transparentColor = QColor(Qt::transparent).rgba();
374 QImage image = bitmap.toImage().convertToFormat(QImage::Format_RGBA8888);
375 QImage maskImage = mask.toImage().convertToFormat(QImage::Format_RGB32);
377 for (
int row = 0; row < image.height(); ++row) {
378 auto *imageData =
reinterpret_cast<QRgb *>(image.scanLine(row));
379 auto *maskData =
reinterpret_cast<QRgb *>(maskImage.scanLine(row));
380 for (
int col = 0; col < image.width(); ++col) {
381 if (maskData[col] == maskTransparentColor)
382 imageData[col] = transparentColor;
391 QBitmap cursorPixels(cursorSize);
392 cursorPixels.fill(Qt::transparent);
393 QBitmap cursorMask(cursorSize);
394 cursorMask.fill(Qt::color0);
395 return QCursor(cursorPixels, cursorMask);
402 auto viewGeometryPersistencePolicy = ViewGeometryPersistencePolicy::Ignore;
406 case WindowGeometryPersistencePolicy
::Disabled:
407 viewGeometryPersistencePolicy = ViewGeometryPersistencePolicy::Disabled;
409 case WindowGeometryPersistencePolicy
::Enabled:
410 viewGeometryPersistencePolicy = ViewGeometryPersistencePolicy::Enabled;
413 viewGeometryPersistencePolicy = ViewGeometryPersistencePolicy::FollowSystemSetting;
417 return viewGeometryPersistencePolicy;
427 bool geometryPersistenceEnabled =
false;
430 case WindowGeometryPersistencePolicy
::Disabled:
433 case WindowGeometryPersistencePolicy
::Enabled:
442 return geometryPersistenceEnabled
448 QWindow *logicalParent, QOhosWindowProxy &windowProxy)
450 auto *screen = logicalParent->screen();
451 auto *ohosPlatformScreen = screen !=
nullptr
455 return ohosPlatformScreen !=
nullptr
456 ? makeQOhosOptional(ohosPlatformScreen->displayInfo().id)
462 if (window !=
nullptr) {
463 QWindowPrivate *windowPrivate = qt_window_private(window);
464 QPalette palette = windowPrivate->windowPalette();
465 QColor backgroundColor = palette.color(QPalette::Window);
466 return makeQOhosOptional(backgroundColor);
475 auto optPostSurfaceDrawTask =
std::exchange(m_optPostSurfaceDrawTask, {});
476 if (optPostSurfaceDrawTask)
477 optPostSurfaceDrawTask();
480std::shared_ptr<QOhosWindowProxy>
QOhosView::tryCreateWindowProxyIfNeeded(ViewType viewType, QWindow *optLogicalParent)
482 QWindow *qWindow = m_ownerWindow;
485 std::shared_ptr<QOhosWindowProxy> result;
488 case ViewType::MainWindow:
492 if (useAutoStartedMainWindow) {
494 createInfo.qWindowRef = QtOhos::QObjectThreadSafeRef(qWindow);
496 return jsState.defaultQAbilityPeer()->instanceId();
502 createInfo.qWindowRef = QtOhos::QObjectThreadSafeRef(qWindow);
503 createInfo.windowId = window->internalWindowId();
504 createInfo
.windowTitle = qWindow->title().toStdString();
505 createInfo.frameGeometry = window->windowFrameGeometry();
506 createInfo.fullscreen = qWindow->windowState() == Qt::WindowFullScreen;
513 case ViewType::SubWindow:
515 auto *targetWindowToBeSubWindowOf = optLogicalParent;
517 if (Q_UNLIKELY(targetWindowToBeSubWindowOf ==
nullptr))
518 qOhosReportFatalErrorAndAbort(
"Failed to determine valid parent of a SubWindow");
520 if (!targetWindowToBeSubWindowOf->isVisible()) {
521 auto *targetParentPlatformWindow = QOhosPlatformWindow::fromQWindowOrNull(targetWindowToBeSubWindowOf);
522 if (targetParentPlatformWindow !=
nullptr)
523 targetParentPlatformWindow->setVisible(
true);
525 targetWindowToBeSubWindowOf->show();
528 auto *targetWindowToBeSubWindowOfView =
529 QOhosPlatformWindow::fromQWindow(targetWindowToBeSubWindowOf)->ownedViewOrNull();
531 const QOhosView *firstViewWithWindow =
nullptr;
532 switch (targetWindowToBeSubWindowOfView->viewType()) {
533 case ViewType::MainWindow:
534 case ViewType::SubWindow:
535 case ViewType::FloatWindow:
536 firstViewWithWindow = targetWindowToBeSubWindowOfView;
538 case ViewType::EmbeddedWindow:
539 firstViewWithWindow = ancestorViewWithWindowOrNull();
543 if (firstViewWithWindow ==
nullptr)
544 qOhosReportFatalErrorAndAbort(
"Failed to determine valid parent for this window.");
546 auto parentWindowProxy = firstViewWithWindow->m_ohosWindowProxy;
547 if (Q_UNLIKELY(!parentWindowProxy)) {
548 qOhosReportFatalErrorAndAbort(
549 "parentWindowProxy is null but should not be. This is most likely a programming error");
553 createInfo
.windowTitle = qWindow->title().toStdString();
554 createInfo.windowId = window->internalWindowId();
559 createInfo.modal = qWindow->modality() != Qt::NonModal;
560 result = parentWindowProxy->createSubWindow(createInfo);
564 case ViewType::EmbeddedWindow:
569 case ViewType::FloatWindow:
572 .qWindowRef = QtOhos::QObjectThreadSafeRef(qWindow),
573 .internalWindowId = window->internalWindowId(),
574 .displayId = window->tryTakeLastRequestedDisplayId(),
580 qOhosReportFatalErrorAndAbort(
"Unsupported view type: %d", viewType);
584 if (result !=
nullptr) {
585 auto viewPtr = QPointer<
QOhosView>(
this);
586 std::weak_ptr<QOhosWindowProxy> weakWindowProxy = result;
587 auto shouldEmitSignalPredicate = [weakWindowProxy](
QOhosView &view) {
588 auto windowProxy = weakWindowProxy.lock();
589 return windowProxy !=
nullptr && windowProxy.get() == view.m_ohosWindowProxy.get();
592 result->setWindowCallbackReceiver(
595 .onWindowEvent = makeViewConditionalSignalEmitter(viewPtr, shouldEmitSignalPredicate, &QOhosView::windowEvent),
599 .onAvoidAreaChange = makeViewConditionalSignalEmitter(viewPtr, shouldEmitSignalPredicate, &QOhosView::avoidAreaChanged),
600 .onWindowRectChange = makeViewConditionalSignalEmitter(viewPtr, shouldEmitSignalPredicate, &QOhosView::windowRectChanged),
604 result->setNonClientAreaMouseWindowCallbackReceiver(
606 [viewPtr, shouldEmitSignalPredicate](std::vector<QOhosWindowProxy::NonClientAreaMouseEvent> &&batch) {
607 if (!viewPtr.isNull() && shouldEmitSignalPredicate(*viewPtr)) {
609 inputEventHandler->onNonClientAreaMouseEvents(viewPtr->m_ownerWindow,
std::move(batch));
613 result->setNonClientAreaTouchWindowCallbackReceiver(
615 [viewPtr, shouldEmitSignalPredicate](std::vector<QOhosWindowProxy::NonClientAreaTouchEvent> &&batch) {
616 if (!viewPtr.isNull() && shouldEmitSignalPredicate(*viewPtr)) {
618 inputEventHandler->onNonClientAreaTouchEvents(viewPtr->m_ownerWindow,
std::move(batch));
622 if (result->qtIsMainWindow() && result->isFocused().valueOr(
false)) {
626 sendAsyncSyntheticWindowActiveEvent();
633bool QOhosView::isWindowTransparencyRequested()
const
635 return m_ownerWindow->requestedFormat().hasAlpha();
639 : m_windowPropertiesProvider(windowPropertyProvider)
644 , m_updatePending(
false)
651 return m_ohosWindowProxy !=
nullptr
652 ? m_ohosWindowProxy->getWindowAvoidArea(avoidAreaType)
653 : AvoidAreaCache::AvoidArea{};
657 this, &QOhosView::avoidAreaChanged,
659 [avoidAreasProvider](QOhosWindowProxy::
AvoidAreaType avoidAreaType,
const QOhosWindowProxy::AvoidArea &avoidArea) {
660 avoidAreasProvider->put(avoidAreaType, avoidArea);
663 m_avoidAreasProvider = [avoidAreasProvider](QOhosWindowProxy::AvoidAreaType type) {
664 return avoidAreasProvider->getStoredOrRetrieveFromWindowProxy(type);
668 m_nativeNode.get(), &QNativeNode::surfaceStatusChanged,
669 this, [
this](
const QOhosOptional<QSize> &optSurfaceSize) {
670 Q_EMIT surfaceStatusChanged(optSurfaceSize);
677 m_nativeNode->setNodeAreaChangeHandler(
678 [
this](
auto nodeAreaChangeEvent) {
679 Q_EMIT nodeAreaChanged(nodeAreaChangeEvent);
682 std::vector<std::shared_ptr<
void>> writeCallbacks = {
683 m_windowPropertiesProvider.addPropertyWriteCallback<
double, &QOhosPlatformWindow::windowCornerRadiusProperty>(
684 [
this](
double windowCornerRadius) {
685 setWindowCornerRadius(windowCornerRadius);
687 m_windowPropertiesProvider.addPropertyWriteCallback<
bool, &QOhosPlatformWindow::windowPrivacyModeSettingProperty>(
688 [
this](
bool windowPrivacyModeSetting) {
689 setPrivacyMode(windowPrivacyModeSetting);
691 m_windowPropertiesProvider.addPropertyWriteCallback<QColor, &QOhosPlatformWindow::surfaceBackgroundColorProperty>(
692 [
this](QColor surfaceBackgroundColor) {
693 setBackgroundColor(surfaceBackgroundColor);
695 m_windowPropertiesProvider.addPropertyWriteCallback<
bool, &QOhosPlatformWindow::windowKeepScreenOnProperty>(
696 [
this](
bool keepScreenOn) {
697 setWindowKeepScreenOn(keepScreenOn);
699 m_windowPropertiesProvider.addPropertyWriteCallback<
bool, &QOhosPlatformWindow::windowFixedSizeStateProperty>(
700 [
this](
bool fixedSizeStateEnabled) {
701 setFixedSizeStateEnabled(fixedSizeStateEnabled);
703 m_windowPropertiesProvider.addPropertyWriteCallback<
int, &QOhosPlatformWindow::windowBrightnessProperty>(
704 [
this](
int brightness) {
705 setBrightness(brightness);
707 m_windowPropertiesProvider.addPropertyWriteCallback<
int, &QOhosPlatformWindow::windowContrastProperty>(
708 [
this](
int contrast) {
709 setContrast(contrast);
711 m_windowPropertiesProvider.addPropertyWriteCallback<
int, &QOhosPlatformWindow::windowSaturationProperty>(
712 [
this](
int saturation) {
713 setSaturation(saturation);
717 m_windowPropertiesProviderCallbacksHandle = QtOhos::moveToSharedPtr(std::move(writeCallbacks));
726 m_nativeNode.reset();
731 setSystemUpdateProperty(&SystemUpdateData::position, {position, {}});
737 setSystemUpdateProperty(&SystemUpdateData::position, {position, makeQOhosOptional(jsDisplayId)});
738 flushSystemPropertyUpdatesImmediate();
743 if (size.isEmpty()) {
744 qCCritical(QtForOhos) <<
"Attempting to resize the system window to invalid size window:"
745 << m_ownerWindow <<
"requestedSize:" << size;
746 qOhosReportFatalErrorAndAbort(
747 "Invalid window size specification window id: %s size: %d,%d",
749 QOhosPlatformWindow::fromQWindow(m_ownerWindow)->internalWindowId().toString()),
750 size.width(), size.height());
753 setSystemUpdateProperty(&SystemUpdateData::size, size);
758 setSystemUpdateProperty(&SystemUpdateData::sizeLimits, std::make_pair(minSize, maxSize));
763 setSystemUpdateProperty(&SystemUpdateData::backgroundTransparent, transparent);
768 setSystemUpdateProperty(&SystemUpdateData::focusable, focusable);
771void QOhosView::setBackgroundColor(
const QColor &color)
773 setSystemUpdateProperty(&SystemUpdateData::backgroundColor, color);
776void QOhosView::setBrightness(
int brightness)
778 setSystemUpdateProperty(&SystemUpdateData::brightness, brightness);
783 setSystemUpdateProperty(&SystemUpdateData::contrast, contrast);
786void QOhosView::setSaturation(
int saturation)
788 setSystemUpdateProperty(&SystemUpdateData::saturation, saturation);
791void QOhosView::setWindowKeepScreenOn(
bool keepScreenOn)
793 if (m_ohosWindowProxy !=
nullptr)
794 m_ohosWindowProxy->setWindowKeepScreenOn(keepScreenOn);
797void QOhosView::setFixedSizeStateEnabled(
bool enabled)
799 if (viewType() != ViewType::MainWindow)
804 "%s: fixed size state is not supported while in HandheldDeviceFullScreen mode",
810 const auto supportedWindowModes = enabled
811 ? std::set<SupportWindowMode>({SupportWindowMode::FLOATING})
812 : std::set<SupportWindowMode>({SupportWindowMode::FULL_SCREEN, SupportWindowMode::FLOATING, SupportWindowMode::SPLIT});
814 m_ohosWindowProxy->setSupportedWindowModes(supportedWindowModes);
819 auto *ohosPlatformWindow =
static_cast<QOhosPlatformWindow *>(m_ownerWindow->handle());
820 m_ohosWindowProxy->showWindow(
821 QOhosWindowProxy::ShowWindowOptions{
822 .focusOnShow = ohosPlatformWindow->shouldShowWindowWithoutActivating()
823 ? makeQOhosOptional(
false)
824 : makeEmptyQOhosOptional(),
828void QOhosView::sendAsyncSyntheticWindowActiveEvent()
830 QMetaObject::invokeMethod(
833 QOhosWindowProxy::WindowEvent syntheticWindowActiveEvent = {
834 .type = QOhosWindowProxy::WindowEventType::WINDOW_ACTIVE,
836 Q_EMIT windowEvent(syntheticWindowActiveEvent);
838 Qt::QueuedConnection);
843 setSystemUpdateProperty(&SystemUpdateData::cursor, cursor);
848 setSystemUpdateProperty(&SystemUpdateData::modality, modality);
853 setSystemUpdateProperty(&SystemUpdateData::title, title);
858 switch (viewType()) {
859 case ViewType::MainWindow:
862 case ViewType::SubWindow:
863 m_ohosWindowProxy->raiseToAppTop();
865 case ViewType::FloatWindow:
867 case ViewType::EmbeddedWindow:
868 m_nativeNode->raise();
875 if (m_ohosWindowProxy !=
nullptr && m_ownerWindow->isVisible())
878 m_nativeNode->lower();
881void QOhosView::updateWindowSize(
const QSize &size)
883 if (m_ohosWindowProxy !=
nullptr)
884 m_ohosWindowProxy->setSize(size);
886 m_nativeNode->setSize(size);
889void QOhosView::updateWindowPosition(
const std::pair<QPoint, QOhosOptional<QOhosDisplayInfo::JsDisplayId>> &positionProp)
893 std::tie(position, displayId) = positionProp;
895 if (m_ohosWindowProxy !=
nullptr) {
896 m_ohosWindowProxy->moveWindowToGlobal(
898 QOhosWindowProxy::MoveConfiguration {
899 .displayId = displayId,
902 m_nativeNode->setPosition(position);
906void QOhosView::updateWindowBackgroundTransparency(
bool transparent)
908 if (m_ohosWindowProxy !=
nullptr) {
909 auto opaqueSystemBackgroundRgb = QGuiApplicationPrivate::platformTheme()
910 ->palette(QPlatformTheme::SystemPalette)
914 m_ohosWindowProxy->setWindowBackgroundColor(
916 ? QColor(Qt::transparent)
917 : tryGetBackgroundColorFromWindow(m_ownerWindow).valueOr(
918 QColor(opaqueSystemBackgroundRgb)));
922void QOhosView::updateWindowCursor(
const QCursor &cursor)
924 if (m_ohosWindowProxy ==
nullptr)
927 if (cursor.shape() == Qt::BitmapCursor || cursor.shape() == Qt::BlankCursor) {
929 cursor.shape() == Qt::BlankCursor
930 ? makeTransparentBitmapCursor({1, 1})
933 QImage bitmapCursorImage = bitmapCursor.pixmap().isNull()
934 ? createImageFromBitmapAndMask(getCursorBitmap(bitmapCursor), getCursorMask(bitmapCursor))
935 : bitmapCursor.pixmap().toImage();
937 m_ohosWindowProxy->setCustomCursor(bitmapCursorImage, bitmapCursor.hotSpot());
939 m_ohosWindowProxy->setPointerStyleSync(cursor);
943void QOhosView::updateWindowFocusable(
bool focusable)
945 if (m_ohosWindowProxy !=
nullptr)
946 m_ohosWindowProxy->setWindowFocusable(focusable);
947 m_nativeNode->setFocusable(focusable);
950void QOhosView::updateWindowBackgroundColor(
const QColor &color)
952 m_nativeNode->setBackgroundColor(color);
955void QOhosView::updateWindowBrightness(
int brightness)
957 m_nativeNode->setBrightness(brightness);
960void QOhosView::updateWindowContrast(
int contrast)
962 m_nativeNode->setContrast(contrast);
965void QOhosView::updateWindowSaturation(
int saturation)
967 m_nativeNode->setSaturation(saturation);
970void QOhosView::updateWindowTransparentForInput(
bool transparentForInput)
972 if (m_ohosWindowProxy !=
nullptr)
973 m_ohosWindowProxy->setWindowTouchable(!transparentForInput);
974 m_nativeNode->setTransparentForInput(transparentForInput);
977void QOhosView::updateWindowSizeLimits(
const std::pair<QSize, QSize> &sizeLimits)
979 if (m_ohosWindowProxy !=
nullptr) {
980 auto windowMargins = QOhosPlatformWindow::fromQWindow(m_ownerWindow)->frameMargins();
981 m_ohosWindowProxy->setWindowLimits(
982 getQSizeGrownBy(sizeLimits.first, windowMargins),
983 getQSizeGrownBy(sizeLimits.second, windowMargins));
987void QOhosView::updateWindowModality(Qt::WindowModality modality)
989 if (m_ohosWindowProxy !=
nullptr) {
990 if (viewType() != ViewType::SubWindow) {
991 qCWarning(QtForOhos,
"%s: Modality is supported only for sub-windows.", Q_FUNC_INFO);
994 if (modality == Qt::WindowModality::ApplicationModal) {
997 "%s: Qt::ApplicationModal policy is unsupported by the platform. The window will behave like Qt::WindowModal.",
1001 auto ohosModalityType = mapQtWindowModalityToOhosOrDefault(modality);
1002 if (ohosModalityType.hasValue())
1003 m_ohosWindowProxy->setSubWindowModalEnabled(ohosModalityType.value());
1005 m_ohosWindowProxy->setSubWindowModalDisabled();
1009void QOhosView::updateWindowTitle(
const QString &title)
1011 if (m_ohosWindowProxy !=
nullptr)
1012 m_ohosWindowProxy->setTitle(title);
1015void QOhosView::scheduleSystemUpdateIfNeeded()
1017 if (m_updatePending)
1019 m_updatePending = QMetaObject::invokeMethod(
1022 flushSystemPropertyUpdatesImmediate();
1024 Qt::QueuedConnection);
1029 return m_ownerWindow;
1034 auto *platformWindow = QOhosPlatformWindow::fromQWindow(m_ownerWindow);
1036 auto currentViewTypeInfo = determineViewTypeAndLogicalParent(platformWindow);
1037 bool viewTypeChanged = viewType() != currentViewTypeInfo.viewType;
1039 if (viewTypeChanged) {
1040 auto qOhosWindowProxy = tryCreateWindowProxyIfNeeded(currentViewTypeInfo.viewType, currentViewTypeInfo.optLogicalParent);
1042 if (qOhosWindowProxy !=
nullptr
1043 && currentViewTypeInfo.viewType == ViewType::SubWindow) {
1044 constexpr bool preventSubWindowClose =
true;
1045 qOhosWindowProxy->setSubWindowCloseHandler(
1047 if (!m_ownerWindow.isNull()) {
1048 qOhosPrintfDebug(
"onSubWindowCloseHandler: calling close()");
1049 QOhosCloseEventContext::runWithCloseRootCauseSet(
1050 QOhosCloseEventContext::CloseRootCause::SubWindowClose,
1052 m_ownerWindow->close();
1056 preventSubWindowClose);
1059 if (qOhosWindowProxy !=
nullptr) {
1060 m_nativeNode->setParent(qOhosWindowProxy->nodeXComponent());
1061 m_nativeNode->fillToParent(m_ownerWindow->handle()->windowGeometry().size());
1064 setOrResetWindowProxy(qOhosWindowProxy, currentViewTypeInfo.optLogicalParent);
1066 syncWindowStateImmediate();
1069 if (viewType() == ViewType::MainWindow) {
1070 const auto windowStates = m_ownerWindow->windowStates();
1071 if (windowStates.testFlag(Qt::WindowState::WindowFullScreen)) {
1073 if (!viewTypeChanged) {
1076 }
else if (windowStates.testFlag(Qt::WindowState::WindowMaximized)) {
1079 }
else if (viewType() == ViewType::SubWindow && m_ohosWindowProxy !=
nullptr) {
1080 m_ohosWindowProxy->setFollowParentMultiScreenPolicy(
true);
1083 if (m_ohosWindowProxy !=
nullptr) {
1089 if (surface !=
nullptr)
1092 m_nativeNode->setVisibility(
true);
1097 if (m_ohosWindowProxy !=
nullptr)
1098 m_ohosWindowProxy->maximize(QOhosWindowProxy::MaximizePresentation::ENTER_IMMERSIVE);
1103 if (m_ohosWindowProxy !=
nullptr)
1104 m_ohosWindowProxy->recover();
1109 if (m_ohosWindowProxy !=
nullptr)
1110 m_ohosWindowProxy->minimize();
1115 if (m_ohosWindowProxy !=
nullptr) {
1116 if (QGuiApplicationPrivate::focus_window) {
1117 const auto *focusPlatformWindow = QOhosPlatformWindow::fromQWindow(QGuiApplicationPrivate::focus_window);
1118 const auto *focusView = focusPlatformWindow->ownedViewOrNull();
1119 if (focusView && focusView !=
this) {
1120 if (focusView->m_ohosWindowProxy) {
1121 focusView->m_ohosWindowProxy->shiftAppWindowFocus(*m_ohosWindowProxy);
1124 sendAsyncSyntheticWindowActiveEvent();
1130 sendAsyncSyntheticWindowActiveEvent();
1136 if (m_ohosWindowProxy !=
nullptr)
1137 m_ohosWindowProxy->maximize(QOhosWindowProxy::MaximizePresentation::EXIT_IMMERSIVE);
1142 auto *qWindow = window->window();
1143 QNativeNode::CreateInfo createInfo;
1144 createInfo.geometry = window->geometry();
1145 createInfo.window = qWindow;
1146 createInfo.backgroundColor = windowPropertiesProvider.tryGetProperty<QColor, &QOhosPlatformWindow::surfaceBackgroundColorProperty>();
1147 createInfo.renderFitPolicyHint =
1150 QPlatformWindow *parentPlatformWindow = window->parent();
1152 if (parentPlatformWindow !=
nullptr) {
1154 auto *parentView = parentPlatformWindow->ownedViewOrNull();
1155 createInfo.optParent = parentView !=
nullptr
1156 ? makeQOhosOptional(parentView->m_nativeNode.get())
1160 auto nativeNode = QSharedPointer<QNativeNode>::create(createInfo);
1161 return std::make_unique<
QOhosView>(qWindow, nativeNode, windowPropertiesProvider);
1167 if (m_ohosWindowProxy !=
nullptr) {
1168 auto windowProperties = m_ohosWindowProxy->getWindowProperties();
1169 result.frameGeometry = windowProperties.windowRect;
1171 result.geometry = windowProperties.drawableRect.translated(windowProperties.windowRect.topLeft());
1176 result.geometry.setSize(
1177 evaluateGeometrySizeBasedOnFrameGeometry(result.geometry.topLeft(), result.frameGeometry));
1178 result.displayId = windowProperties.displayId;
1180 result.frameGeometry = m_nativeNode->geometry().toRect();
1181 result.geometry = result.frameGeometry;
1183 const auto *ancestorViewWithWindow = ancestorViewWithWindowOrNull();
1184 result.displayId = ancestorViewWithWindow !=
nullptr
1185 ? ancestorViewWithWindow->m_ohosWindowProxy->getWindowProperties().displayId
1194 auto avoidArea = m_avoidAreasProvider(type);
1196 tryUpdateMaximumMarginsFromAvoidArea(margins, avoidArea);
1202 if (!m_ohosWindowProxy)
1203 return ViewType::EmbeddedWindow;
1205 switch (m_ohosWindowProxy->windowProxyType()) {
1206 case WindowProxyType::FloatWindow:
1207 return ViewType::FloatWindow;
1208 case WindowProxyType::MainWindow:
1209 return ViewType::MainWindow;
1210 case WindowProxyType::SubWindow:
1211 return ViewType::SubWindow;
1214 qOhosReportFatalErrorAndAbort(
"Unrecognized WindowProxyType: %d",
static_cast<
int>(m_ohosWindowProxy->windowProxyType()));
1219 auto *platformWindow = QOhosPlatformWindow::fromQWindow(m_ownerWindow);
1220 auto targetWindowGeometry = getTargetSystemWindowGeometryForPlatformWindow(
1221 viewType(), platformWindow, platformWindow->screen());
1223 m_updateData.position.optPendingUpdateRequest = {targetWindowGeometry.topLeft(), {}};
1224 m_updateData.size.optPendingUpdateRequest = targetWindowGeometry.size();
1225 scheduleSystemUpdateIfNeeded();
1230 switch (viewType()) {
1231 case ViewType::MainWindow:
1234 case ViewType::FloatWindow:
1235 case ViewType::SubWindow:
1237 setOrResetWindowProxy(
nullptr,
nullptr);
1238 auto syntheticWindowHiddenEvent = QOhosWindowProxy::
WindowEvent {
1241 Q_EMIT windowEvent(syntheticWindowHiddenEvent);
1244 case ViewType::EmbeddedWindow:
1245 m_nativeNode->setVisibility(
false);
1246 Q_EMIT windowVisibilityChange(
false);
1258 if (m_ohosWindowProxy !=
nullptr)
1259 m_ohosWindowProxy->setWindowMask(mask);
1264 return m_nativeNode->surfaceOrNull();
1269 return m_nativeNode->windowId();
1274 qCDebug(QtForOhos) <<
"view:" <<
this <<
"setParentOrReparent parentView:" << &parentView;
1275 m_nativeNode->setParent(*parentView.m_nativeNode);
1276 setOrResetWindowProxy(
nullptr, parentView.ownerWindow());
1281 if (viewType() != ViewType::EmbeddedWindow) {
1282 qCDebug(QtForOhos) << Q_FUNC_INFO << m_ownerWindow;
1286 m_nativeNode->detachFromParentIfPresent();
1287 m_optLogicalParent =
nullptr;
1289 if (m_ownerWindow->isVisible() && !m_ohosWindowProxy)
1295 m_nativeNode->setVisibility(visible);
1296 m_lastMainWindowHideMethod = WindowHideMethod::NativeNodeVisibility;
1301 if (QOhosDeviceInfo::is2in1() && m_ohosWindowProxy->tryHideAbility()) {
1302 m_lastMainWindowHideMethod = WindowHideMethod::HideAbility;
1306 m_ohosWindowProxy->minimize();
1307 m_lastMainWindowHideMethod = WindowHideMethod::Minimize;
1312 if (viewType() == ViewType::EmbeddedWindow && m_optLogicalParent ==
nullptr)
1315 std::vector<std::function<
void()>> postSurfaceDrawTasks;
1316 auto updatePostSurfaceDrawTask = qScopeGuard([&]() {
1317 if (!postSurfaceDrawTasks.empty()) {
1318 m_optPostSurfaceDrawTask = [postSurfaceDrawTasks = std::move(postSurfaceDrawTasks)]() {
1319 for (
const auto &task: postSurfaceDrawTasks)
1325 if (reason == WindowStateSyncReason::ViewTypeChanged && m_ohosWindowProxy
1326 && viewType() == ViewType::MainWindow) {
1327 postSurfaceDrawTasks.emplace_back(
1328 [weakWindowProxy = QtOhos::makeWeakPtr(m_ohosWindowProxy)]() {
1329 auto windowProxy = weakWindowProxy.lock();
1331 windowProxy->removeStartingWindow();
1335 auto *platformWindow = QOhosPlatformWindow::fromQWindow(m_ownerWindow);
1337 auto targetWindowLimitsToSet =
1338 viewType() == ViewType::EmbeddedWindow
1339 ? std::make_pair(m_ownerWindow->minimumSize(), m_ownerWindow->maximumSize())
1340 : std::make_pair(platformWindow->windowMinimumSize(), platformWindow->windowMaximumSize());
1342 auto windowFlags = QOhosPlatformWindow::platformWindowFlagsForQWindow(m_ownerWindow);
1343 bool focusable = !windowFlags.testFlag(Qt::WindowDoesNotAcceptFocus);
1345 auto submitSystemPropertyUpdate = [](
auto &targetProperty,
const auto &targetValue) {
1346 targetProperty.optPendingUpdateRequest = targetValue;
1349 auto submitOrResetSystemPropertyUpdate = [&submitSystemPropertyUpdate](
1350 auto &targetProperty,
1351 const auto &targetValue,
1354 targetProperty.optPendingUpdateRequest.reset();
1356 submitSystemPropertyUpdate(targetProperty, targetValue);
1359 submitSystemPropertyUpdate(m_updateData.title, m_ownerWindow->title());
1361 auto windowGeometryPersistenceState =
1362 viewType() == ViewType::MainWindow
1363 && m_geometryPersistencePolicy != ViewGeometryPersistencePolicy::Ignore
1364 ? syncWindowGeometryPersistenceState(m_ohosWindowProxy.get())
1365 : WindowGeometryPersistenceState::Disabled;
1368 bool windowGeometrySyncEnabled =
false;
1369 switch (currentRuntimeDeviceTypeAndMode) {
1372 windowGeometrySyncEnabled =
true;
1374 case QOhosRuntimeDeviceTypeAndMode::HandheldDeviceFullScreen:
1375 windowGeometrySyncEnabled = viewType() != ViewType::MainWindow;
1380 switch (viewType()) {
1381 case ViewType::SubWindow:
1382 if (m_optLogicalParent ==
nullptr)
1383 qOhosReportFatalErrorAndAbort(
"%s: logical parent for a subwindow is null", Q_FUNC_INFO);
1384 targetDisplayId = tryGetSubWindowJsDisplayId(m_optLogicalParent, *m_ohosWindowProxy);
1386 case ViewType::MainWindow:
1388 auto lastRequestedDisplayId = platformWindow->tryTakeLastRequestedDisplayId();
1389 targetDisplayId = lastRequestedDisplayId.hasValue()
1390 ? lastRequestedDisplayId
1391 : m_ohosWindowProxy->tryGetMainWindowJsDisplayId();
1394 case ViewType::FloatWindow:
1395 case ViewType::EmbeddedWindow:
1403 auto *targetScreen = displayIdPlatformScreen !=
nullptr
1404 ? displayIdPlatformScreen
1405 : platformWindow->screen();
1407 auto targetGeometryToSet =
1408 getTargetSystemWindowGeometryForPlatformWindow(viewType(), platformWindow, targetScreen);
1410 if (windowGeometrySyncEnabled) {
1411 submitSystemPropertyUpdate(m_updateData.sizeLimits, targetWindowLimitsToSet);
1412 submitOrResetSystemPropertyUpdate(
1413 m_updateData.size, targetGeometryToSet.size(), windowGeometryPersistenceState);
1415 submitOrResetSystemPropertyUpdate(
1416 m_updateData.position,
1417 std::make_pair(targetGeometryToSet.topLeft(), targetDisplayId),
1418 windowGeometryPersistenceState);
1421 submitSystemPropertyUpdate(m_updateData.backgroundTransparent, isWindowTransparencyRequested());
1424 submitSystemPropertyUpdate(m_updateData.focusable, focusable);
1426 if (viewType() == ViewType::SubWindow)
1427 submitSystemPropertyUpdate(m_updateData.modality, m_ownerWindow->modality());
1429 submitSystemPropertyUpdate(
1430 m_updateData.windowMinMaxCloseButtonsState,
1432 .maxButtonShown = windowFlags.testFlag(Qt::WindowMaximizeButtonHint),
1433 .minButtonShown = windowFlags.testFlag(Qt::WindowMinimizeButtonHint),
1434 .closeButtonShown = windowFlags.testFlag(Qt::WindowCloseButtonHint),
1437 submitSystemPropertyUpdate(
1438 m_updateData.windowStaysOnTop, windowFlags.testFlag(Qt::WindowStaysOnTopHint));
1440 submitSystemPropertyUpdate(m_updateData.frameless, windowFlags.testFlag(Qt::FramelessWindowHint));
1442 submitSystemPropertyUpdate(
1443 m_updateData.windowTransparentForInput, windowFlags.testFlag(Qt::WindowTransparentForInput));
1445 flushSystemPropertyUpdatesImmediate();
1447 bool disableWindowShadow = windowFlags.testFlag(Qt::WindowType::NoDropShadowWindowHint);
1448 if (disableWindowShadow)
1451 if (!m_ownerWindow->mask().isNull() && m_ohosWindowProxy !=
nullptr) {
1452 m_ohosWindowProxy->setWindowMask(
1453 QOhosWindowProxy::WindowMask {
1454 .windowMaskRegion = m_ownerWindow->mask(),
1456 makeQOhosOptional(targetGeometryToSet.size()));
1458 const auto privacyModeSetting = m_windowPropertiesProvider
1459 .tryGetProperty<
bool, &QOhosPlatformWindow::windowPrivacyModeSettingProperty>();
1460 if (privacyModeSetting.hasValue())
1461 setPrivacyMode(privacyModeSetting.value());
1463 const auto windowCornerRadius = m_windowPropertiesProvider
1464 .tryGetProperty<
double, &QOhosPlatformWindow::windowCornerRadiusProperty>();
1465 if (windowCornerRadius.hasValue())
1466 setWindowCornerRadius(windowCornerRadius.value());
1468 const auto keepScreenOn = m_windowPropertiesProvider
1469 .tryGetProperty<
bool, &QOhosPlatformWindow::windowKeepScreenOnProperty>();
1470 if (keepScreenOn.hasValue())
1471 setWindowKeepScreenOn(keepScreenOn.value());
1473 auto fixedSizeStateEnabled = m_windowPropertiesProvider
1474 .tryGetProperty<
bool, &QOhosPlatformWindow::windowFixedSizeStateProperty>();
1475 if (fixedSizeStateEnabled.hasValue())
1476 setFixedSizeStateEnabled(fixedSizeStateEnabled.value());
1479void QOhosView::flushSystemPropertyUpdatesImmediate()
1481 static const auto systemDataPropertyUpdateFuncPairsTuple = makeSystemUpdateDataPropertyUpdateFuncPairsTuple();
1484 systemDataPropertyUpdateFuncPairsTuple,
1485 [&](
const auto &updateDataMemberPtrUpdateFuncPair) {
1486 auto memberPtr = updateDataMemberPtrUpdateFuncPair.first;
1487 auto updateFuncPtr = updateDataMemberPtrUpdateFuncPair.second;
1488 auto &property = m_updateData.*memberPtr;
1489 auto optUpdateRequest =
std::exchange(property.optPendingUpdateRequest, {});
1490 if (optUpdateRequest.hasValue())
1491 (
this->*updateFuncPtr)(optUpdateRequest.value());
1493 m_updatePending =
false;
1498 m_nativeNode->addForeignWindowChild(foreignWindow);
1503 auto *surface = m_nativeNode->surfaceOrNull();
1504 return surface !=
nullptr
1505 ? surface->surfaceResolution()
1511 return m_ohosWindowProxy !=
nullptr
1512 ? m_ohosWindowProxy->getImmersiveModeEnabledState()
1518 if (viewType() == ViewType::SubWindow) {
1519 auto *screen = m_ownerWindow->screen();
1520 return screen !=
nullptr && m_ownerWindow->geometry().size() == screen->geometry().size();
1528 if (m_ohosWindowProxy !=
nullptr) {
1529 m_ohosWindowProxy->setWindowTitleButtonVisible(
1530 state.maxButtonShown, state.minButtonShown, state.closeButtonShown);
1534void QOhosView::updateWindowStaysOnTop(
bool staysOnTop)
1536 if (m_ohosWindowProxy !=
nullptr)
1537 m_ohosWindowProxy->setWindowTopmost(staysOnTop);
1540void QOhosView::updateWindowFrameless(
bool frameless)
1542 bool supportsFramelessWindow = viewType() == ViewType::MainWindow || viewType() == ViewType::SubWindow;
1543 if (m_ohosWindowProxy !=
nullptr && supportsFramelessWindow) {
1544 m_ohosWindowProxy->setWindowDecorVisible(!frameless);
1545 m_ohosWindowProxy->setWindowTitleMoveEnabled(!frameless);
1551 setSystemUpdateProperty(&SystemUpdateData::windowMinMaxCloseButtonsState, state);
1556 setSystemUpdateProperty(&SystemUpdateData::windowStaysOnTop, staysOnTop);
1561 setSystemUpdateProperty(&SystemUpdateData::frameless, frameless);
1566 if (m_ohosWindowProxy !=
nullptr) {
1567 constexpr double windowShadowDisabledRadius = 0.0;
1568 m_ohosWindowProxy->setWindowShadowRadius(windowShadowDisabledRadius);
1572void QOhosView::setWindowCornerRadius(
double radius)
1574 if (m_ohosWindowProxy !=
nullptr)
1575 m_ohosWindowProxy->setWindowCornerRadius(radius);
1580 setSystemUpdateProperty(&SystemUpdateData::windowTransparentForInput, transparentForInput);
1585 if (m_ohosWindowProxy !=
nullptr)
1586 return m_ohosWindowProxy->startMoving();
1590void QOhosView::setPrivacyMode(
bool privacyModeEnabled)
1592 if (m_ohosWindowProxy !=
nullptr)
1593 m_ohosWindowProxy->setWindowPrivacyMode(privacyModeEnabled);
1597 const std::vector<QImage> &images,
const QPointF &hotspot,
1598 const QMimeData &mimeData, QOhosConsumer<Qt::DropAction> dropActionConsumer)
1600 m_nativeNode->startDrag(images, hotspot, mimeData, std::move(dropActionConsumer));
1606 if (m_ohosWindowProxy ==
nullptr || !m_ohosWindowProxy->qtIsMainWindow())
1609 if (!lastMainWindowHideMethod.hasValue()) {
1610 m_ohosWindowProxy->restore();
1614 switch (lastMainWindowHideMethod.value()) {
1615 case WindowHideMethod::NativeNodeVisibility:
1616 case WindowHideMethod::Minimize:
1617 m_ohosWindowProxy->restore();
1619 case WindowHideMethod::HideAbility:
1620 m_ohosWindowProxy->showAbility();
1626 Qt::WindowStates previousWindowState, Qt::WindowStates currentWindowState)
1628 auto stateChange = previousWindowState ^ currentWindowState;
1629 if (stateChange.testFlag(Qt::WindowState::WindowMinimized) && !currentWindowState.testFlag(Qt::WindowState::WindowMinimized))
1632 if (stateChange.testFlag(Qt::WindowState::WindowMaximized) && currentWindowState.testFlag(Qt::WindowState::WindowMaximized)) {
1637 if (stateChange.testFlag(Qt::WindowState::WindowFullScreen) && currentWindowState.testFlag(Qt::WindowState::WindowFullScreen)) {
1642 if (stateChange.testFlag(Qt::WindowState::WindowMinimized) && currentWindowState.testFlag(Qt::WindowState::WindowMinimized)) {
1647 if (!currentWindowState) {
1654 Qt::WindowFlags previousWindowFlags, Qt::WindowFlags currentWindowFlags)
1656 const auto flagsChange = previousWindowFlags ^ currentWindowFlags;
1658 bool minMaxCloseButtonStateChanged = (flagsChange & (Qt::WindowMinMaxButtonsHint | Qt::WindowCloseButtonHint)) != 0;
1659 bool framelessChanged = (flagsChange & Qt::FramelessWindowHint) != 0;
1661 if (minMaxCloseButtonStateChanged || framelessChanged) {
1663 .maxButtonShown = currentWindowFlags.testFlag(Qt::WindowMaximizeButtonHint),
1664 .minButtonShown = currentWindowFlags.testFlag(Qt::WindowMinimizeButtonHint),
1665 .closeButtonShown = currentWindowFlags.testFlag(Qt::WindowCloseButtonHint),
1669 bool windowStaysOnTopChanged = (flagsChange & Qt::WindowStaysOnTopHint) != 0;
1670 if (windowStaysOnTopChanged)
1673 bool transparentForInputChanged = (flagsChange & Qt::WindowTransparentForInput) != 0;
1674 if (transparentForInputChanged)
1677 if (framelessChanged)
1680 bool focusableChanged = (flagsChange & Qt::WindowDoesNotAcceptFocus) != 0;
1681 if (focusableChanged) {
1682 bool windowAcceptsFocus = !currentWindowFlags.testFlag(Qt::WindowDoesNotAcceptFocus);
1686 bool disableWindowShadowChanged = (flagsChange & Qt::NoDropShadowWindowHint) != 0;
1687 if (disableWindowShadowChanged && currentWindowFlags.testFlag(Qt::NoDropShadowWindowHint))
1700 return !(*
this == other);
1703void QOhosView::setOrResetWindowProxy(
std::shared_ptr<QOhosWindowProxy> windowProxy, QWindow *optLogicalParent)
1705 m_ohosWindowProxy.reset();
1706 m_ohosWindowProxy = windowProxy
1707 ? QtOhos::makeSharedPtrWithAttachedExtraData<QOhosWindowProxy>(
1709 QWindowProxyRegistry::instance().registerQWindowWithWindowProxy(ownerWindow(), *windowProxy))
1711 m_optLogicalParent = optLogicalParent;
1717 auto *platformWindow = m_optLogicalParent !=
nullptr
1718 ? QOhosPlatformWindow::fromQWindowOrNull(m_optLogicalParent)
1721 return platformWindow !=
nullptr
1722 ? platformWindow->ownedViewOrNull()
1729 while (parent !=
nullptr && !parent->m_ohosWindowProxy)
1732 return parent !=
nullptr && parent->m_ohosWindowProxy
1739 return m_ohosWindowProxy ? m_ohosWindowProxy->snapshot() : QPixmap();
1744 return m_nativeNode->nodeScreenGeometryPixels();
1749 return m_nativeNode->nodeParentRelativeGeometryPixels();
void externalContentClickDetected()
std::enable_if_t< qohosplugincore_h_detail::isQOhosOptional< QOhosInvokeResult< Func, T > >, QOhosInvokeResult< Func, T > > andThen(Func &&func) const
QOhosPlatformScreen * platformScreenForDisplayIdOrNull(QOhosDisplayInfo::JsDisplayId displayId) const
void clearNativeWindowSurface()
void windowStatusChange(QOhosWindowProxy::WindowStatus windowStatus)
void setParentOrReparent(QOhosView &parentView)
void setCursor(const QCursor &cursor)
void handleWindowFlagsChange(Qt::WindowFlags previousWindowFlags, Qt::WindowFlags currentWindowFlags)
void addForeignWindowChild(QOhosForeignWindow *foreignWindow)
void handleWindowStateChange(Qt::WindowStates previousWindowState, Qt::WindowStates currentWindowState)
void setFocusable(bool focusable)
QOhosSurface * surfaceOrNull() const
void windowVisibilityChange(bool visibility)
void setPositionOnScreenImmediate(const QPoint &position, QOhosDisplayInfo::JsDisplayId jsDisplayId)
void setTransparentBackground(bool transparent)
void setModality(Qt::WindowModality modality)
bool isFullscreenImmersiveModeEnabled()
void setFramelessWindow(bool frameless)
QPixmap makeSnapshot() const
void setWindowShadowDisabled()
void setWindowTransparentForInput(bool transparentForInput)
void tryDetachFromEmbeddedParent()
ViewType viewType() const
QMargins avoidAreaMargins(QOhosWindowProxy::AvoidAreaType type) const
QWindow * ownerWindow() const
void handleSurfaceContentsUpdated()
QOhosOptional< QSize > surfaceResolution() const
void forceGeometryUpdate()
void externalContentInteractionDetected()
void setWindowMinMaxCloseButtonState(const WindowMinMaxCloseButtonsState &state)
void setWindowMask(const QOhosWindowProxy::WindowMask &windowMask)
void setSizeLimits(const QSize &minSize, const QSize &maxSize)
void windowTouchOutside()
void handlePaletteChange()
void windowDisplayIdChanged(QOhosDisplayInfo::JsDisplayId)
void setNativeNodeVisibility(bool visible)
void setWindowStaysOnTop(bool staysOnTop)
ViewGeometry viewGeometry() const
void setSize(const QSize &size)
void setPosition(const QPoint &position)
QOhosView(QWindow *ownerWindow, QSharedPointer< QNativeNode > nativeNode, QOhosPropertiesProvider propertiesProvider)
bool isSubWindowCoveringFullScreen() const
QRect nodeParentRelativeGeometryPixels() const
void setTitle(const QString &title)
const QOhosView * viewParentOrNull() const
QRect nodeScreenGeometryPixels() const
void setWindowRectAutoSave(bool enabed)
static std::shared_ptr< QOhosWindowProxy > createFloatWindow(const FloatWindowCreateInfo &createInfo)
QOhosWindowProxyExistingMainWindowCreateInfo ExistingMainWindowCreateInfo
static std::shared_ptr< QOhosWindowProxy > createForExistingMainWindow(const ExistingMainWindowCreateInfo &createInfo)
bool isWindowRectAutoSave() const
QOhosWindowProxySubWindowCreateInfo SubWindowCreateInfo
QOhosWindowProxyMainWindowCreateInfo MainWindowCreateInfo
QOhosWindowProxyFloatWindowCreateInfo FloatWindowCreateInfo
QtOhos::enums::ohos::bundle::bundleManager::SupportWindowMode SupportWindowMode
QOhosOptional< QOhosDisplayInfo::JsDisplayId > tryGetMainWindowJsDisplayId() const
static std::shared_ptr< QOhosWindowProxy > createMainWindow(const MainWindowCreateInfo &createInfo)
QOhosWindowProxy::AvoidAreaType AvoidAreaType
AvoidAreaCache(std::function< AvoidArea(AvoidAreaType)> avoidAreasProvider)
AvoidArea getStoredOrRetrieveFromWindowProxy(AvoidAreaType avoidAreaType)
void put(AvoidAreaType avoidAreaType, const AvoidArea &avoidArea)
static QWindowProxyRegistry & instance()
Combined button and popup list for selecting options.
QRect correctFrameGeometryPositionFitToAvailableArea(const QRect &geometry, const QRect &availableArea)
QOhosOptional< QOhosWindowProxy::ModalityType > mapQtWindowModalityToOhosOrDefault(Qt::WindowModality windowModality)
QSize evaluateGeometrySizeBasedOnFrameGeometry(const QPoint &geometryOrigin, const QRect &frameGeometry)
std::function< void(SignalParams...)> makeViewConditionalSignalEmitter(QPointer< QOhosView > viewPtr, std::function< bool(QOhosView &)> predicate, void(QOhosView::*signalFuncPtr)(SignalParams ...))
QRect tryCorrectFrameGeometry(QOhosPlatformWindow *platformWindow, QPlatformScreen *targetScreen)
QOhosOptional< QColor > tryGetBackgroundColorFromWindow(QWindow *window)
QCursor makeTransparentBitmapCursor(QSize cursorSize)
QWindow * syntheticParentForQWindowOrNull(QWindow *qWindow)
QBitmap getCursorMask(const QCursor &cursor)
WindowGeometryPersistenceState
QSize getQSizeGrownBy(const QSize &size, const QMargins &margins)
void tryUpdateMaximumMarginsFromAvoidArea(QMargins &marginsToUpdate, const QOhosWindowProxy::AvoidArea &avoidArea)
QWindow * getFirstTopLevelWindowWithSystemFocusOrNull()
QWindow * getFirstTopLevelWindowOrNull()
QRect correctFrameGeometryPositionFitToReachableArea(const QRect &geometry, const QRect &availableArea, const QRect &screenGeometry)
QOhosOptional< QOhosDisplayInfo::JsDisplayId > tryGetSubWindowJsDisplayId(QWindow *logicalParent, QOhosWindowProxy &windowProxy)
QBitmap getCursorBitmap(const QCursor &cursor)
ViewGeometryPersistencePolicy determineViewGeometryPersistencePolicy()
ViewTypeInfo determineViewTypeAndLogicalParent(const QOhosPlatformWindow *platformWindow)
QRect getTargetSystemWindowGeometryForPlatformWindow(QOhosView::ViewType viewType, QOhosPlatformWindow *platformWindow, QPlatformScreen *targetScreen)
WindowGeometryPersistenceState syncWindowGeometryPersistenceState(QOhosWindowProxy *windowProxy)
QImage createImageFromBitmapAndMask(const QBitmap &bitmap, const QBitmap &mask)
bool acquireAndCleanPendingAutoStartedInstanceWindowFlag()
QOhosOptional< void > makeEmptyQOhosOptional()
bool isHandheldDeviceType()
QOhosRuntimeDeviceTypeAndMode
@ HandheldDeviceFullScreen
@ HandheldDeviceWindowPcMode
QOhosRuntimeDeviceTypeAndMode queryQOhosRuntimeDeviceAndMode()
std::string qAbilityInstanceId
bool disableWindowFocusableBeforeLoadContentHack
std::string qAbilityInstanceId
QWindow * optLogicalParent
QOhosView::ViewType viewType