dde-dock/plugins/datetime/datetimewidget.cpp

179 lines
5.6 KiB
C++
Raw Normal View History

/*
* Copyright (C) 2011 ~ 2018 Deepin Technology Co., Ltd.
*
* Author: sbw <sbw@sbw.so>
*
* Maintainer: sbw <sbw@sbw.so>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "datetimewidget.h"
#include "constants.h"
#include <QApplication>
#include <QPainter>
#include <QDebug>
#include <QSvgRenderer>
#include <QMouseEvent>
#include <DFontSizeManager>
#include <DGuiApplicationHelper>
#define PLUGIN_STATE_KEY "enable"
2019-11-19 11:26:11 +08:00
#define SHOW_DATE_MIN_HEIGHT 40
#define TIME_FONT DFontSizeManager::instance()->t4()
#define DATE_FONT DFontSizeManager::instance()->t10()
DWIDGET_USE_NAMESPACE
DatetimeWidget::DatetimeWidget(QWidget *parent)
: QWidget(parent)
{
QFontMetrics fm_time(TIME_FONT);
int timeHeight = fm_time.boundingRect("88:88").height();
QFontMetrics fm_date(DATE_FONT);
int dateHeight = fm_date.boundingRect("8888/88/88").height();
m_timeOffset = (timeHeight - dateHeight) / 2;
2019-09-06 14:44:07 +08:00
setMinimumSize(PLUGIN_BACKGROUND_MIN_SIZE, PLUGIN_BACKGROUND_MIN_SIZE);
}
void DatetimeWidget::set24HourFormat(const bool value)
{
if (m_24HourFormat == value) {
return;
}
m_24HourFormat = value;
update();
2019-11-06 16:22:19 +08:00
adjustSize();
if (isVisible()) {
emit requestUpdateGeometry();
}
}
QSize DatetimeWidget::curTimeSize() const
{
2019-09-06 14:44:07 +08:00
const Dock::Position position = qApp->property(PROP_POSITION).value<Dock::Position>();
m_timeFont = TIME_FONT;
QFontMetrics fm(m_timeFont);
2019-09-06 14:44:07 +08:00
QString format;
if (m_24HourFormat)
format = "hh:mm";
else {
if (position == Dock::Top || position == Dock::Bottom)
format = "hh:mm AP";
else
format = "hh:mm\nAP";
}
2019-09-06 14:44:07 +08:00
QString timeString = QDateTime::currentDateTime().toString(format);
QSize timeSize = fm.boundingRect(timeString).size();
if (timeString.contains("\n")) {
QStringList SL = timeString.split("\n");
timeSize = QSize(fm.boundingRect(SL.at(0)).width(), fm.boundingRect(SL.at(0)).height() + fm.boundingRect(SL.at(1)).height());
} else {
QSize dateSize = QFontMetrics(DATE_FONT).boundingRect("0000/00/00").size();
if (timeSize.width() < dateSize.width())
timeSize.setWidth(dateSize.width());
}
2019-09-06 14:44:07 +08:00
if (position == Dock::Bottom || position == Dock::Top) {
2019-11-06 16:22:19 +08:00
return QSize(timeSize.width(), height());
2019-09-06 14:44:07 +08:00
} else {
if (width() < timeSize.width()) {
if (timeString.contains("\n")) {
QStringList SL = timeString.split("\n");
while (QFontMetrics(m_timeFont).boundingRect(SL.at(0)).size().width() > width()) {
m_timeFont.setPixelSize(m_timeFont.pixelSize() - 1);
}
} else {
while (QFontMetrics(m_timeFont).boundingRect(timeString).size().width() > width()) {
m_timeFont.setPixelSize(m_timeFont.pixelSize() - 1);
}
}
int timeHeight = QFontMetrics(m_timeFont).boundingRect(timeString).size().height();
if (format.contains("\n")) {
QStringList SL = format.split("\n");
timeHeight = QFontMetrics(m_timeFont).boundingRect(SL.at(0)).size().height() + QFontMetrics(m_timeFont).boundingRect(SL.at(1)).size().height();
}
2019-11-06 16:22:19 +08:00
return QSize(width(), std::max(timeHeight, PLUGIN_BACKGROUND_MIN_SIZE));
} else {
2019-11-06 16:22:19 +08:00
return QSize(width(), std::max(timeSize.height(), SHOW_DATE_MIN_HEIGHT));
}
2019-09-06 14:44:07 +08:00
}
}
QSize DatetimeWidget::sizeHint() const
{
return curTimeSize();
}
void DatetimeWidget::resizeEvent(QResizeEvent *e)
{
setMaximumSize(curTimeSize() + QSize(1, 1));
2019-09-06 14:44:07 +08:00
QWidget::resizeEvent(e);
}
void DatetimeWidget::paintEvent(QPaintEvent *e)
{
Q_UNUSED(e);
const QDateTime current = QDateTime::currentDateTime();
QPainter painter(this);
painter.setRenderHint(QPainter::Antialiasing);
const Dock::Position position = qApp->property(PROP_POSITION).value<Dock::Position>();
2019-08-19 14:57:11 +08:00
QString format;
if (m_24HourFormat)
format = "hh:mm";
else {
if (position == Dock::Top || position == Dock::Bottom)
format = "hh:mm AP";
else
format = "hh:mm\nAP";
}
painter.setFont(m_timeFont);
painter.setPen(QPen(palette().brightText(), 1));
if (rect().height() >= SHOW_DATE_MIN_HEIGHT) {
QRect timeRect = rect();
timeRect.setBottom(rect().center().y() + m_timeOffset);
if (position == Dock::Top || position == Dock::Bottom) {
painter.drawText(timeRect, Qt::AlignBottom | Qt::AlignHCenter, current.toString(format));
QRect dateRect = rect();
dateRect.setTop(timeRect.bottom());
format = "yyyy/MM/dd";
painter.setFont(DATE_FONT);
painter.drawText(dateRect, Qt::AlignTop | Qt::AlignHCenter, current.toString(format));
} else {
painter.drawText(rect(), Qt::AlignVCenter | Qt::AlignHCenter, current.toString(format));
}
} else {
painter.drawText(rect(), Qt::AlignCenter, current.toString(format));
}
}