// Copyright (C) 2011 ~ 2018 Deepin Technology Co., Ltd. // SPDX-FileCopyrightText: 2018 - 2023 UnionTech Software Technology Co., Ltd. // // SPDX-License-Identifier: LGPL-3.0-or-later #include "onboarditem.h" #include #include #include #include #include #include #include DWIDGET_USE_NAMESPACE; OnboardItem::OnboardItem(QWidget *parent) : QWidget(parent) , m_hover(false) , m_pressed(false) { setMouseTracking(true); setMinimumSize(PLUGIN_BACKGROUND_MIN_SIZE, PLUGIN_BACKGROUND_MIN_SIZE); connect(DGuiApplicationHelper::instance(), &DGuiApplicationHelper::themeTypeChanged, this, [ = ] { update(); }); m_icon = QIcon::fromTheme(":/icons/icon/deepin-virtualkeyboard.svg"); } QPixmap OnboardItem::iconPixmap(QSize size, DGuiApplicationHelper::ColorType themeType) const { QString iconName = "deepin-virtualkeyboard"; if (std::min(width(), height()) <= PLUGIN_BACKGROUND_MIN_SIZE || themeType == DGuiApplicationHelper::LightType) iconName.append(PLUGIN_MIN_ICON_NAME); return loadSvg(iconName, size); } void OnboardItem::paintEvent(QPaintEvent *e) { Q_UNUSED(e); QPainter painter(this); if (std::min(width(), height()) > PLUGIN_BACKGROUND_MIN_SIZE) { QColor color; if (DGuiApplicationHelper::instance()->themeType() == DGuiApplicationHelper::LightType) { color = Qt::black; painter.setOpacity(0.5); if (m_hover) { painter.setOpacity(0.6); } if (m_pressed) { painter.setOpacity(0.3); } } else { color = Qt::white; painter.setOpacity(0.1); if (m_hover) { painter.setOpacity(0.2); } if (m_pressed) { painter.setOpacity(0.05); } } painter.setRenderHint(QPainter::Antialiasing, true); DStyleHelper dstyle(style()); const int radius = dstyle.pixelMetric(DStyle::PM_FrameRadius); QPainterPath path; int minSize = std::min(width(), height()); QRect rc(0, 0, minSize, minSize); rc.moveTo(rect().center() - rc.center()); path.addRoundedRect(rc, radius, radius); painter.fillPath(path, color); } QPixmap pixmap = iconPixmap(QSize(PLUGIN_ICON_MAX_SIZE, PLUGIN_ICON_MAX_SIZE), DGuiApplicationHelper::instance()->themeType()); painter.setOpacity(1); const QRectF &rf = QRectF(rect()); const QRectF &rfp = QRectF(pixmap.rect()); painter.drawPixmap(rf.center() - rfp.center() / devicePixelRatioF(), pixmap); } const QPixmap OnboardItem::loadSvg(const QString &fileName, const QSize &size) const { const auto ratio = devicePixelRatioF(); QSize pixmapSize = QCoreApplication::testAttribute(Qt::AA_UseHighDpiPixmaps) ? size : (size * ratio); QPixmap pixmap = QIcon::fromTheme(fileName, m_icon).pixmap(pixmapSize); pixmap.setDevicePixelRatio(ratio); pixmap = pixmap.scaled(size * ratio); return pixmap; } void OnboardItem::mousePressEvent(QMouseEvent *event) { m_pressed = true; update(); QWidget::mousePressEvent(event); } void OnboardItem::mouseReleaseEvent(QMouseEvent *event) { m_pressed = false; m_hover = false; update(); QWidget::mouseReleaseEvent(event); } void OnboardItem::mouseMoveEvent(QMouseEvent *event) { m_hover = true; QWidget::mouseMoveEvent(event); } void OnboardItem::leaveEvent(QEvent *event) { m_hover = false; m_pressed = false; update(); QWidget::leaveEvent(event); } void OnboardItem::resizeEvent(QResizeEvent *event) { QWidget::resizeEvent(event); }