summaryrefslogtreecommitdiffstats
path: root/gui/logindialog.cpp
diff options
context:
space:
mode:
authorSky <git@bunnies.cc>2013-10-19 06:40:46 +0100
committerSky <git@bunnies.cc>2013-10-19 06:40:46 +0100
commit681d36b23251993a8678db8e72859d4018396b63 (patch)
tree9082d1bc7107c1b1d0bc7b72fb486bd84cd21560 /gui/logindialog.cpp
parentbe2c7f451541647899478d0197d3e9500d63c833 (diff)
downloadMultiMC-681d36b23251993a8678db8e72859d4018396b63.tar
MultiMC-681d36b23251993a8678db8e72859d4018396b63.tar.gz
MultiMC-681d36b23251993a8678db8e72859d4018396b63.tar.lz
MultiMC-681d36b23251993a8678db8e72859d4018396b63.tar.xz
MultiMC-681d36b23251993a8678db8e72859d4018396b63.zip
First draft of player faces in the login dialog
Diffstat (limited to 'gui/logindialog.cpp')
-rw-r--r--gui/logindialog.cpp50
1 files changed, 50 insertions, 0 deletions
diff --git a/gui/logindialog.cpp b/gui/logindialog.cpp
index ed3983b7..332b5d38 100644
--- a/gui/logindialog.cpp
+++ b/gui/logindialog.cpp
@@ -17,6 +17,13 @@
#include "ui_logindialog.h"
#include "keyring.h"
#include "gui/platform.h"
+#include "MultiMC.h"
+
+#include <QFile>
+#include <QJsonObject>
+#include <QJsonArray>
+#include <QJsonParseError>
+#include "logic/net/HttpMetaCache.h"
#include <logger/QsLog.h>
LoginDialog::LoginDialog(QWidget *parent, const QString& loginErrMsg) :
@@ -51,6 +58,8 @@ LoginDialog::LoginDialog(QWidget *parent, const QString& loginErrMsg) :
arg(loginErrMsg));
}
+ ui->lblFace->setVisible(false);
+
resize(minimumSizeHint());
layout()->setSizeConstraint(QLayout::SetFixedSize);
Keyring * k = Keyring::instance();
@@ -151,13 +160,54 @@ void LoginDialog::userTextChanged ( const QString& user )
blockToggles = true;
Keyring * k = Keyring::instance();
QStringList sl = k->getStoredAccounts("minecraft");
+ bool gotFace = false;
+
if(sl.contains(user))
{
ui->rememberUsernameCheckbox->setChecked(true);
QString passwd = k->getPassword("minecraft",user);
ui->rememberPasswordCheckbox->setChecked(!passwd.isEmpty());
ui->passwordTextBox->setText(passwd);
+
+ QByteArray data;
+ {
+ auto filename = MMC->metacache()->resolveEntry("skins", "skins.json")->getFullPath();
+ QFile listFile(filename);
+ if(!listFile.open(QIODevice::ReadOnly))
+ return;
+ data = listFile.readAll();
+ }
+
+ QJsonParseError jsonError;
+ QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &jsonError);
+ QJsonObject root = jsonDoc.object();
+ QJsonObject mappings = root.value("mappings").toObject();
+
+ if(!mappings[user].isUndefined())
+ {
+ QJsonArray usernames = mappings.value(user).toArray();
+ if(!usernames.isEmpty())
+ {
+ QString mapped_username = usernames[0].toString();
+
+ if(!mapped_username.isEmpty())
+ {
+ QFile fskin(MMC->metacache()->resolveEntry("skins", mapped_username + ".png")->getFullPath());
+ if(fskin.exists())
+ {
+ QPixmap skin(MMC->metacache()->resolveEntry("skins", mapped_username + ".png")->getFullPath());
+ QPixmap face = skin.copy(8, 8, 8, 8).scaled(48, 48, Qt::KeepAspectRatio);
+
+ ui->lblFace->setPixmap(face);
+ gotFace = true;
+ }
+ }
+ }
+ }
}
+
+ if(gotFace) ui->lblFace->setVisible(true);
+ else ui->lblFace->setVisible(false);
blockToggles = false;
}