mirror of
https://github.com/qTox/qTox.git
synced 2024-03-22 14:00:36 +08:00
Added MaskablePixmapWidget, improved avatar rendering
This commit is contained in:
parent
dfc40aa8e8
commit
5662aa933f
BIN
img/avatar_mask.png
Normal file
BIN
img/avatar_mask.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 5.6 KiB |
BIN
img/avatar_mask_circle.png
Normal file
BIN
img/avatar_mask_circle.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 9.1 KiB |
|
@ -6,8 +6,8 @@
|
||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>716</width>
|
<width>714</width>
|
||||||
<height>543</height>
|
<height>541</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="minimumSize">
|
<property name="minimumSize">
|
||||||
|
@ -1452,32 +1452,20 @@ QSplitter:handle{
|
||||||
<number>0</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
<item>
|
<item>
|
||||||
<widget class="ClickableLabel" name="profilePicture">
|
<spacer name="horizontalSpacer_4">
|
||||||
<property name="minimumSize">
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
<property name="sizeType">
|
||||||
|
<enum>QSizePolicy::Maximum</enum>
|
||||||
|
</property>
|
||||||
|
<property name="sizeHint" stdset="0">
|
||||||
<size>
|
<size>
|
||||||
<width>40</width>
|
<width>5</width>
|
||||||
<height>40</height>
|
<height>20</height>
|
||||||
</size>
|
</size>
|
||||||
</property>
|
</property>
|
||||||
<property name="maximumSize">
|
</spacer>
|
||||||
<size>
|
|
||||||
<width>40</width>
|
|
||||||
<height>40</height>
|
|
||||||
</size>
|
|
||||||
</property>
|
|
||||||
<property name="text">
|
|
||||||
<string/>
|
|
||||||
</property>
|
|
||||||
<property name="pixmap">
|
|
||||||
<pixmap resource="res.qrc">:/img/contact.png</pixmap>
|
|
||||||
</property>
|
|
||||||
<property name="scaledContents">
|
|
||||||
<bool>false</bool>
|
|
||||||
</property>
|
|
||||||
<property name="wordWrap">
|
|
||||||
<bool>true</bool>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout" stretch="1,1">
|
<layout class="QVBoxLayout" name="verticalLayout" stretch="1,1">
|
||||||
|
@ -2095,8 +2083,8 @@ QSplitter:handle{
|
||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>263</width>
|
<width>262</width>
|
||||||
<height>378</height>
|
<height>375</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_5"/>
|
<layout class="QVBoxLayout" name="verticalLayout_5"/>
|
||||||
|
@ -3230,8 +3218,8 @@ QSplitter:handle{
|
||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>716</width>
|
<width>714</width>
|
||||||
<height>19</height>
|
<height>25</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
|
@ -3257,11 +3245,6 @@ QSplitter:handle{
|
||||||
<extends>QLabel</extends>
|
<extends>QLabel</extends>
|
||||||
<header>widget/croppinglabel.h</header>
|
<header>widget/croppinglabel.h</header>
|
||||||
</customwidget>
|
</customwidget>
|
||||||
<customwidget>
|
|
||||||
<class>ClickableLabel</class>
|
|
||||||
<extends>QLabel</extends>
|
|
||||||
<header>widget/tool/clickablelabel.h</header>
|
|
||||||
</customwidget>
|
|
||||||
</customwidgets>
|
</customwidgets>
|
||||||
<resources>
|
<resources>
|
||||||
<include location="res.qrc"/>
|
<include location="res.qrc"/>
|
||||||
|
|
5
qtox.pro
5
qtox.pro
|
@ -117,7 +117,7 @@ HEADERS += widget/form/addfriendform.h \
|
||||||
widget/tool/chatactions/messageaction.h \
|
widget/tool/chatactions/messageaction.h \
|
||||||
widget/tool/chatactions/filetransferaction.h \
|
widget/tool/chatactions/filetransferaction.h \
|
||||||
widget/tool/chatactions/systemmessageaction.h \
|
widget/tool/chatactions/systemmessageaction.h \
|
||||||
widget/tool/clickablelabel.h
|
widget/maskablepixmapwidget.h
|
||||||
|
|
||||||
SOURCES += \
|
SOURCES += \
|
||||||
widget/form/addfriendform.cpp \
|
widget/form/addfriendform.cpp \
|
||||||
|
@ -157,4 +157,5 @@ SOURCES += \
|
||||||
widget/settingsdialog.cpp \
|
widget/settingsdialog.cpp \
|
||||||
widget/tool/chatactions/messageaction.cpp \
|
widget/tool/chatactions/messageaction.cpp \
|
||||||
widget/tool/chatactions/filetransferaction.cpp \
|
widget/tool/chatactions/filetransferaction.cpp \
|
||||||
widget/tool/chatactions/systemmessageaction.cpp
|
widget/tool/chatactions/systemmessageaction.cpp \
|
||||||
|
widget/maskablepixmapwidget.cpp
|
||||||
|
|
2
res.qrc
2
res.qrc
|
@ -142,5 +142,7 @@
|
||||||
<file>translations/pl.qm</file>
|
<file>translations/pl.qm</file>
|
||||||
<file>translations/fi.qm</file>
|
<file>translations/fi.qm</file>
|
||||||
<file>translations/mannol.qm</file>
|
<file>translations/mannol.qm</file>
|
||||||
|
<file>img/avatar_mask.png</file>
|
||||||
|
<file>img/avatar_mask_circle.png</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include <QMimeData>
|
#include <QMimeData>
|
||||||
#include <QFileInfo>
|
#include <QFileInfo>
|
||||||
#include <QDragEnterEvent>
|
#include <QDragEnterEvent>
|
||||||
|
#include <QBitmap>
|
||||||
#include "chatform.h"
|
#include "chatform.h"
|
||||||
#include "friend.h"
|
#include "friend.h"
|
||||||
#include "widget/friendwidget.h"
|
#include "widget/friendwidget.h"
|
||||||
|
@ -32,12 +33,13 @@
|
||||||
#include "widget/tool/chattextedit.h"
|
#include "widget/tool/chattextedit.h"
|
||||||
#include "core.h"
|
#include "core.h"
|
||||||
#include "widget/widget.h"
|
#include "widget/widget.h"
|
||||||
|
#include "widget/maskablepixmapwidget.h"
|
||||||
|
|
||||||
ChatForm::ChatForm(Friend* chatFriend)
|
ChatForm::ChatForm(Friend* chatFriend)
|
||||||
: f(chatFriend)
|
: f(chatFriend)
|
||||||
{
|
{
|
||||||
nameLabel->setText(f->getName());
|
nameLabel->setText(f->getName());
|
||||||
avatarLabel->setPixmap(QPixmap(":/img/contact_dark.png"));
|
avatar->setPixmap(QPixmap(":/img/contact_dark.png"));
|
||||||
|
|
||||||
statusMessageLabel = new CroppingLabel();
|
statusMessageLabel = new CroppingLabel();
|
||||||
netcam = new NetCamView();
|
netcam = new NetCamView();
|
||||||
|
@ -475,8 +477,7 @@ void ChatForm::onAvatarChange(int FriendId, const QPixmap &pic)
|
||||||
if (FriendId != f->friendId)
|
if (FriendId != f->friendId)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
QPixmap scaled = pic.scaled(40,40,Qt::KeepAspectRatio,Qt::SmoothTransformation);
|
avatar->setPixmap(pic);
|
||||||
avatarLabel->setPixmap(scaled);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ChatForm::dragEnterEvent(QDragEnterEvent *ev)
|
void ChatForm::dragEnterEvent(QDragEnterEvent *ev)
|
||||||
|
|
|
@ -26,6 +26,7 @@
|
||||||
#include "widget/tool/chatactions/systemmessageaction.h"
|
#include "widget/tool/chatactions/systemmessageaction.h"
|
||||||
#include "widget/chatareawidget.h"
|
#include "widget/chatareawidget.h"
|
||||||
#include "widget/tool/chattextedit.h"
|
#include "widget/tool/chattextedit.h"
|
||||||
|
#include "widget/maskablepixmapwidget.h"
|
||||||
|
|
||||||
GenericChatForm::GenericChatForm(QWidget *parent) :
|
GenericChatForm::GenericChatForm(QWidget *parent) :
|
||||||
QWidget(parent)
|
QWidget(parent)
|
||||||
|
@ -35,7 +36,7 @@ GenericChatForm::GenericChatForm(QWidget *parent) :
|
||||||
headWidget = new QWidget();
|
headWidget = new QWidget();
|
||||||
|
|
||||||
nameLabel = new CroppingLabel();
|
nameLabel = new CroppingLabel();
|
||||||
avatarLabel = new QLabel();
|
avatar = new MaskablePixmapWidget(this, QSize(40,40), ":/img/avatar_mask_circle.png");
|
||||||
QHBoxLayout *headLayout = new QHBoxLayout(), *mainFootLayout = new QHBoxLayout();
|
QHBoxLayout *headLayout = new QHBoxLayout(), *mainFootLayout = new QHBoxLayout();
|
||||||
headTextLayout = new QVBoxLayout();
|
headTextLayout = new QVBoxLayout();
|
||||||
QVBoxLayout *mainLayout = new QVBoxLayout();
|
QVBoxLayout *mainLayout = new QVBoxLayout();
|
||||||
|
@ -99,7 +100,7 @@ GenericChatForm::GenericChatForm(QWidget *parent) :
|
||||||
mainFootLayout->setSpacing(0);
|
mainFootLayout->setSpacing(0);
|
||||||
|
|
||||||
headWidget->setLayout(headLayout);
|
headWidget->setLayout(headLayout);
|
||||||
headLayout->addWidget(avatarLabel);
|
headLayout->addWidget(avatar);
|
||||||
headLayout->addLayout(headTextLayout);
|
headLayout->addLayout(headTextLayout);
|
||||||
headLayout->addLayout(volMicLayout);
|
headLayout->addLayout(volMicLayout);
|
||||||
headLayout->addWidget(callButton);
|
headLayout->addWidget(callButton);
|
||||||
|
|
|
@ -30,6 +30,7 @@ class QPushButton;
|
||||||
class CroppingLabel;
|
class CroppingLabel;
|
||||||
class ChatTextEdit;
|
class ChatTextEdit;
|
||||||
class ChatAreaWidget;
|
class ChatAreaWidget;
|
||||||
|
class MaskablePixmapWidget;
|
||||||
|
|
||||||
namespace Ui {
|
namespace Ui {
|
||||||
class MainWindow;
|
class MainWindow;
|
||||||
|
@ -60,7 +61,7 @@ protected slots:
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CroppingLabel *nameLabel;
|
CroppingLabel *nameLabel;
|
||||||
QLabel *avatarLabel;
|
MaskablePixmapWidget *avatar;
|
||||||
QWidget *headWidget;
|
QWidget *headWidget;
|
||||||
QPushButton *fileButton, *emoteButton, *callButton, *videoButton, *volButton, *micButton;
|
QPushButton *fileButton, *emoteButton, *callButton, *videoButton, *volButton, *micButton;
|
||||||
QVBoxLayout *headTextLayout;
|
QVBoxLayout *headTextLayout;
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include "widget/groupwidget.h"
|
#include "widget/groupwidget.h"
|
||||||
#include "widget/tool/chattextedit.h"
|
#include "widget/tool/chattextedit.h"
|
||||||
#include "widget/croppinglabel.h"
|
#include "widget/croppinglabel.h"
|
||||||
|
#include "widget/maskablepixmapwidget.h"
|
||||||
#include "core.h"
|
#include "core.h"
|
||||||
#include <QPushButton>
|
#include <QPushButton>
|
||||||
#include <QMimeData>
|
#include <QMimeData>
|
||||||
|
@ -42,7 +43,7 @@ GroupChatForm::GroupChatForm(Group* chatGroup)
|
||||||
nameLabel->setText(group->widget->name.text());
|
nameLabel->setText(group->widget->name.text());
|
||||||
nusersLabel->setFont(small);
|
nusersLabel->setFont(small);
|
||||||
nusersLabel->setText(GroupChatForm::tr("%1 users in chat","Number of users in chat").arg(group->peers.size()));
|
nusersLabel->setText(GroupChatForm::tr("%1 users in chat","Number of users in chat").arg(group->peers.size()));
|
||||||
avatarLabel->setPixmap(QPixmap(":/img/group_dark.png"));
|
avatar->setPixmap(QPixmap(":/img/group_dark.png"));
|
||||||
|
|
||||||
QString names;
|
QString names;
|
||||||
for (QString& s : group->peers)
|
for (QString& s : group->peers)
|
||||||
|
|
|
@ -22,11 +22,13 @@
|
||||||
#include "friend.h"
|
#include "friend.h"
|
||||||
#include "core.h"
|
#include "core.h"
|
||||||
#include "widget/form/chatform.h"
|
#include "widget/form/chatform.h"
|
||||||
|
#include "widget/maskablepixmapwidget.h"
|
||||||
#include <QContextMenuEvent>
|
#include <QContextMenuEvent>
|
||||||
#include <QMenu>
|
#include <QMenu>
|
||||||
#include <QDrag>
|
#include <QDrag>
|
||||||
#include <QMimeData>
|
#include <QMimeData>
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
|
#include <QBitmap>
|
||||||
|
|
||||||
FriendWidget::FriendWidget(int FriendId, QString id)
|
FriendWidget::FriendWidget(int FriendId, QString id)
|
||||||
: friendId(FriendId), isDefaultAvatar{true}
|
: friendId(FriendId), isDefaultAvatar{true}
|
||||||
|
@ -42,7 +44,8 @@ FriendWidget::FriendWidget(int FriendId, QString id)
|
||||||
textLayout.setMargin(0);
|
textLayout.setMargin(0);
|
||||||
setLayoutDirection(Qt::LeftToRight); // parent might have set Qt::RightToLeft
|
setLayoutDirection(Qt::LeftToRight); // parent might have set Qt::RightToLeft
|
||||||
|
|
||||||
avatar.setPixmap(QPixmap(":img/contact.png"));
|
avatar = new MaskablePixmapWidget(this, QSize(40,40), ":/img/avatar_mask.png");
|
||||||
|
avatar->setPixmap(QPixmap(":img/contact.png"));
|
||||||
name.setText(id);
|
name.setText(id);
|
||||||
//statusPic.setAlignment(Qt::AlignHCenter);
|
//statusPic.setAlignment(Qt::AlignHCenter);
|
||||||
statusPic.setPixmap(QPixmap(":img/status/dot_away.png"));
|
statusPic.setPixmap(QPixmap(":img/status/dot_away.png"));
|
||||||
|
@ -65,7 +68,7 @@ FriendWidget::FriendWidget(int FriendId, QString id)
|
||||||
textLayout.addStretch();
|
textLayout.addStretch();
|
||||||
|
|
||||||
layout.addSpacing(20);
|
layout.addSpacing(20);
|
||||||
layout.addWidget(&avatar);
|
layout.addWidget(avatar);
|
||||||
layout.addSpacing(5);
|
layout.addSpacing(5);
|
||||||
layout.addLayout(&textLayout);
|
layout.addLayout(&textLayout);
|
||||||
layout.addSpacing(5);
|
layout.addSpacing(5);
|
||||||
|
@ -138,7 +141,7 @@ void FriendWidget::setAsActiveChatroom()
|
||||||
pal3.setColor(QPalette::Background, Qt::white);
|
pal3.setColor(QPalette::Background, Qt::white);
|
||||||
this->setPalette(pal3);
|
this->setPalette(pal3);
|
||||||
if (isDefaultAvatar)
|
if (isDefaultAvatar)
|
||||||
avatar.setPixmap(QPixmap(":img/contact_dark.png"));
|
avatar->setPixmap(QPixmap(":img/contact_dark.png"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendWidget::setAsInactiveChatroom()
|
void FriendWidget::setAsInactiveChatroom()
|
||||||
|
@ -159,7 +162,7 @@ void FriendWidget::setAsInactiveChatroom()
|
||||||
this->setPalette(pal3);
|
this->setPalette(pal3);
|
||||||
|
|
||||||
if (isDefaultAvatar)
|
if (isDefaultAvatar)
|
||||||
avatar.setPixmap(QPixmap(":img/contact.png"));
|
avatar->setPixmap(QPixmap(":img/contact.png"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendWidget::updateStatusLight()
|
void FriendWidget::updateStatusLight()
|
||||||
|
@ -203,8 +206,7 @@ void FriendWidget::onAvatarChange(int FriendId, const QPixmap& pic)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
isDefaultAvatar = false;
|
isDefaultAvatar = false;
|
||||||
QPixmap scaled = pic.scaled(40,40,Qt::KeepAspectRatio,Qt::SmoothTransformation);
|
avatar->setPixmap(pic);
|
||||||
avatar.setPixmap(scaled);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendWidget::mousePressEvent(QMouseEvent *ev)
|
void FriendWidget::mousePressEvent(QMouseEvent *ev)
|
||||||
|
@ -225,8 +227,7 @@ void FriendWidget::mouseMoveEvent(QMouseEvent *ev)
|
||||||
mdata->setData("friend", QString::number(friendId).toLatin1());
|
mdata->setData("friend", QString::number(friendId).toLatin1());
|
||||||
|
|
||||||
drag->setMimeData(mdata);
|
drag->setMimeData(mdata);
|
||||||
if (avatar.pixmap())
|
drag->setPixmap(avatar->getPixmap());
|
||||||
drag->setPixmap(*avatar.pixmap());
|
|
||||||
|
|
||||||
drag->exec(Qt::CopyAction | Qt::MoveAction);
|
drag->exec(Qt::CopyAction | Qt::MoveAction);
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
#include "croppinglabel.h"
|
#include "croppinglabel.h"
|
||||||
|
|
||||||
class QPixmap;
|
class QPixmap;
|
||||||
|
class MaskablePixmapWidget;
|
||||||
|
|
||||||
struct FriendWidget : public GenericChatroomWidget
|
struct FriendWidget : public GenericChatroomWidget
|
||||||
{
|
{
|
||||||
|
@ -50,7 +51,8 @@ protected:
|
||||||
|
|
||||||
public:
|
public:
|
||||||
int friendId;
|
int friendId;
|
||||||
QLabel avatar, statusPic;
|
MaskablePixmapWidget* avatar;
|
||||||
|
QLabel statusPic;
|
||||||
CroppingLabel name, statusMessage;
|
CroppingLabel name, statusMessage;
|
||||||
bool isDefaultAvatar;
|
bool isDefaultAvatar;
|
||||||
QPoint dragStartPos;
|
QPoint dragStartPos;
|
||||||
|
|
61
widget/maskablepixmapwidget.cpp
Normal file
61
widget/maskablepixmapwidget.cpp
Normal file
|
@ -0,0 +1,61 @@
|
||||||
|
/*
|
||||||
|
Copyright (C) 2014 by Project Tox <https://tox.im>
|
||||||
|
|
||||||
|
This file is part of qTox, a Qt-based graphical interface for Tox.
|
||||||
|
|
||||||
|
This program is libre 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
|
||||||
|
(at your option) 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 COPYING file for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "maskablepixmapwidget.h"
|
||||||
|
#include <QPainter>
|
||||||
|
#include <QPaintEvent>
|
||||||
|
|
||||||
|
MaskablePixmapWidget::MaskablePixmapWidget(QWidget *parent, QSize size, QString maskName)
|
||||||
|
: QWidget(parent)
|
||||||
|
{
|
||||||
|
setMinimumSize(size);
|
||||||
|
setMaximumSize(size);
|
||||||
|
|
||||||
|
mask = QPixmap(maskName).scaled(maximumSize(), Qt::IgnoreAspectRatio, Qt::SmoothTransformation);
|
||||||
|
}
|
||||||
|
|
||||||
|
void MaskablePixmapWidget::setPixmap(const QPixmap &pmap)
|
||||||
|
{
|
||||||
|
pixmap = pmap.scaled(maximumSize(), Qt::KeepAspectRatio, Qt::SmoothTransformation);
|
||||||
|
}
|
||||||
|
|
||||||
|
QPixmap MaskablePixmapWidget::getPixmap() const
|
||||||
|
{
|
||||||
|
return pixmap;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MaskablePixmapWidget::paintEvent(QPaintEvent *ev)
|
||||||
|
{
|
||||||
|
QPixmap tmp(ev->rect().size());
|
||||||
|
tmp.fill(Qt::transparent);
|
||||||
|
|
||||||
|
QPoint offset((ev->rect().size().width()-pixmap.size().width())/2,(ev->rect().size().height()-pixmap.size().height())/2);
|
||||||
|
|
||||||
|
QPainter painter(&tmp);
|
||||||
|
painter.setCompositionMode(QPainter::CompositionMode_Source);
|
||||||
|
painter.drawPixmap(offset,pixmap);
|
||||||
|
painter.setCompositionMode(QPainter::CompositionMode_DestinationIn);
|
||||||
|
painter.drawPixmap(0,0,mask);
|
||||||
|
|
||||||
|
painter.end();
|
||||||
|
painter.begin(this);
|
||||||
|
painter.drawPixmap(0,0,tmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
void MaskablePixmapWidget::mousePressEvent(QMouseEvent*)
|
||||||
|
{
|
||||||
|
emit clicked();
|
||||||
|
}
|
45
widget/maskablepixmapwidget.h
Normal file
45
widget/maskablepixmapwidget.h
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
/*
|
||||||
|
Copyright (C) 2014 by Project Tox <https://tox.im>
|
||||||
|
|
||||||
|
This file is part of qTox, a Qt-based graphical interface for Tox.
|
||||||
|
|
||||||
|
This program is libre 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
|
||||||
|
(at your option) 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 COPYING file for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef MASKABLEPIXMAPWIDGET_H
|
||||||
|
#define MASKABLEPIXMAPWIDGET_H
|
||||||
|
|
||||||
|
#include <QWidget>
|
||||||
|
|
||||||
|
class MaskablePixmapWidget : public QWidget
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
MaskablePixmapWidget(QWidget *parent, QSize size, QString maskName);
|
||||||
|
|
||||||
|
void setPixmap(const QPixmap &pmap);
|
||||||
|
QPixmap getPixmap() const;
|
||||||
|
|
||||||
|
signals:
|
||||||
|
void clicked();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual void paintEvent(QPaintEvent *ev);
|
||||||
|
virtual void mousePressEvent(QMouseEvent *);
|
||||||
|
|
||||||
|
private:
|
||||||
|
QPixmap pixmap;
|
||||||
|
QPixmap mask;
|
||||||
|
QSize size;
|
||||||
|
QString maskName;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // MASKABLEPIXMAPWIDGET_H
|
|
@ -1,22 +0,0 @@
|
||||||
#ifndef CLICKABLELABEL_H
|
|
||||||
#define CLICKABLELABEL_H
|
|
||||||
|
|
||||||
#include <QLabel>
|
|
||||||
|
|
||||||
class QMouseEvent;
|
|
||||||
class QWidget;
|
|
||||||
|
|
||||||
class ClickableLabel : public QLabel
|
|
||||||
{
|
|
||||||
Q_OBJECT
|
|
||||||
|
|
||||||
public:
|
|
||||||
explicit ClickableLabel(QWidget* parent = 0) : QLabel(parent) {}
|
|
||||||
signals:
|
|
||||||
void clicked();
|
|
||||||
protected:
|
|
||||||
void mousePressEvent (QMouseEvent*) {emit clicked();}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
#endif // CLICKABLELABEL_H
|
|
|
@ -32,6 +32,7 @@
|
||||||
#include "camera.h"
|
#include "camera.h"
|
||||||
#include "widget/form/chatform.h"
|
#include "widget/form/chatform.h"
|
||||||
#include "widget/settingsdialog.h"
|
#include "widget/settingsdialog.h"
|
||||||
|
#include "widget/maskablepixmapwidget.h"
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
|
@ -111,6 +112,10 @@ Widget::Widget(QWidget *parent)
|
||||||
|
|
||||||
isWindowMinimized = 0;
|
isWindowMinimized = 0;
|
||||||
|
|
||||||
|
profilePicture = new MaskablePixmapWidget(this, QSize(40,40), ":/img/avatar_mask.png");
|
||||||
|
profilePicture->setPixmap(QPixmap(":/img/avatar.png"));
|
||||||
|
ui->horizontalLayout_3->insertWidget(0,profilePicture);
|
||||||
|
|
||||||
ui->mainContent->setLayout(new QVBoxLayout());
|
ui->mainContent->setLayout(new QVBoxLayout());
|
||||||
ui->mainHead->setLayout(new QVBoxLayout());
|
ui->mainHead->setLayout(new QVBoxLayout());
|
||||||
ui->mainHead->layout()->setMargin(0);
|
ui->mainHead->layout()->setMargin(0);
|
||||||
|
@ -214,7 +219,7 @@ Widget::Widget(QWidget *parent)
|
||||||
connect(ui->settingsButton, SIGNAL(clicked()), this, SLOT(onSettingsClicked()));
|
connect(ui->settingsButton, SIGNAL(clicked()), this, SLOT(onSettingsClicked()));
|
||||||
connect(ui->nameLabel, SIGNAL(textChanged(QString,QString)), this, SLOT(onUsernameChanged(QString,QString)));
|
connect(ui->nameLabel, SIGNAL(textChanged(QString,QString)), this, SLOT(onUsernameChanged(QString,QString)));
|
||||||
connect(ui->statusLabel, SIGNAL(textChanged(QString,QString)), this, SLOT(onStatusMessageChanged(QString,QString)));
|
connect(ui->statusLabel, SIGNAL(textChanged(QString,QString)), this, SLOT(onStatusMessageChanged(QString,QString)));
|
||||||
connect(ui->profilePicture, SIGNAL(clicked()), this, SLOT(onAvatarClicked()));
|
connect(profilePicture, SIGNAL(clicked()), this, SLOT(onAvatarClicked()));
|
||||||
connect(setStatusOnline, SIGNAL(triggered()), this, SLOT(setStatusOnline()));
|
connect(setStatusOnline, SIGNAL(triggered()), this, SLOT(setStatusOnline()));
|
||||||
connect(setStatusAway, SIGNAL(triggered()), this, SLOT(setStatusAway()));
|
connect(setStatusAway, SIGNAL(triggered()), this, SLOT(setStatusAway()));
|
||||||
connect(setStatusBusy, SIGNAL(triggered()), this, SLOT(setStatusBusy()));
|
connect(setStatusBusy, SIGNAL(triggered()), this, SLOT(setStatusBusy()));
|
||||||
|
@ -322,8 +327,7 @@ void Widget::onAvatarClicked()
|
||||||
|
|
||||||
void Widget::onSelfAvatarLoaded(const QPixmap& pic)
|
void Widget::onSelfAvatarLoaded(const QPixmap& pic)
|
||||||
{
|
{
|
||||||
QPixmap scaled = pic.scaled(40,40, Qt::KeepAspectRatio,Qt::SmoothTransformation);
|
profilePicture->setPixmap(pic);
|
||||||
ui->profilePicture->setPixmap(scaled);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Widget::onConnected()
|
void Widget::onConnected()
|
||||||
|
|
|
@ -38,6 +38,7 @@ class Core;
|
||||||
class Camera;
|
class Camera;
|
||||||
class FriendListWidget;
|
class FriendListWidget;
|
||||||
class SettingsDialog;
|
class SettingsDialog;
|
||||||
|
class MaskablePixmapWidget;
|
||||||
|
|
||||||
class Widget : public QMainWindow
|
class Widget : public QMainWindow
|
||||||
{
|
{
|
||||||
|
@ -144,6 +145,7 @@ private:
|
||||||
GenericChatroomWidget* activeChatroomWidget;
|
GenericChatroomWidget* activeChatroomWidget;
|
||||||
FriendListWidget* contactListWidget;
|
FriendListWidget* contactListWidget;
|
||||||
Camera* camera;
|
Camera* camera;
|
||||||
|
MaskablePixmapWidget* profilePicture;
|
||||||
bool notify(QObject *receiver, QEvent *event);
|
bool notify(QObject *receiver, QEvent *event);
|
||||||
bool eventFilter(QObject *, QEvent *event);
|
bool eventFilter(QObject *, QEvent *event);
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue
Block a user