mirror of
https://github.com/linuxdeepin/dde-dock.git
synced 2025-06-03 00:15:21 +00:00
145 lines
3.7 KiB
C++
145 lines
3.7 KiB
C++
// 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 <QPainter>
|
|
#include <QPainterPath>
|
|
#include <QMouseEvent>
|
|
#include <QApplication>
|
|
#include <QIcon>
|
|
|
|
#include <DStyle>
|
|
#include <DGuiApplicationHelper>
|
|
|
|
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);
|
|
}
|