neobytes/src/qt/receiverequestdialog.cpp

177 lines
4.4 KiB
C++
Raw Normal View History

2013-10-16 15:14:26 +02:00
#include "receiverequestdialog.h"
#include "ui_receiverequestdialog.h"
#include "bitcoinunits.h"
#include "guiconstants.h"
#include "guiutil.h"
#include "optionsmodel.h"
#include "walletmodel.h"
#include <QPixmap>
#include <QClipboard>
#if QT_VERSION < 0x050000
#include <QUrl>
#endif
2013-10-16 15:14:26 +02:00
#include "bitcoin-config.h" /* for USE_QRCODE */
#ifdef USE_QRCODE
#include <qrencode.h>
2013-10-16 15:14:26 +02:00
#endif
QRImageWidget::QRImageWidget(QWidget *parent):
QLabel(parent)
{
setContextMenuPolicy(Qt::ActionsContextMenu);
QAction *saveImageAction = new QAction(tr("&Save Image..."), this);
connect(saveImageAction, SIGNAL(triggered()), this, SLOT(saveImage()));
addAction(saveImageAction);
QAction *copyImageAction = new QAction(tr("&Copy Image"), this);
connect(copyImageAction, SIGNAL(triggered()), this, SLOT(copyImage()));
addAction(copyImageAction);
}
QImage QRImageWidget::exportImage()
{
return pixmap()->toImage().scaled(EXPORT_IMAGE_SIZE, EXPORT_IMAGE_SIZE);
}
void QRImageWidget::mousePressEvent(QMouseEvent *event)
{
if(event->button() == Qt::LeftButton)
{
QMimeData *mimeData = new QMimeData;
mimeData->setImageData(exportImage());
QDrag *drag = new QDrag(this);
drag->setMimeData(mimeData);
drag->exec();
}
}
void QRImageWidget::saveImage()
{
QString fn = GUIUtil::getSaveFileName(this, tr("Save QR Code"), QString(), tr("PNG Images (*.png)"));
if (!fn.isEmpty())
{
exportImage().save(fn);
}
}
void QRImageWidget::copyImage()
{
QApplication::clipboard()->setImage(exportImage());
}
ReceiveRequestDialog::ReceiveRequestDialog(const SendCoinsRecipient &info, QWidget *parent) :
QDialog(parent),
2013-10-16 15:14:26 +02:00
ui(new Ui::ReceiveRequestDialog),
model(0),
info(info)
{
ui->setupUi(this);
QString target = info.label;
2013-10-16 15:14:26 +02:00
if(target.isEmpty())
target = info.address;
2013-10-16 15:14:26 +02:00
setWindowTitle(tr("Request payment to %1").arg(target));
ui->lnAddress->setText(info.address);
if(info.amount)
ui->lnReqAmount->setValue(info.amount);
2013-10-16 15:14:26 +02:00
ui->lnReqAmount->setReadOnly(true);
ui->lnLabel->setText(info.label);
ui->lnMessage->setText(info.message);
2013-10-16 15:14:26 +02:00
#ifndef USE_QRCODE
ui->btnSaveAs->setVisible(false);
ui->lblQRCode->setVisible(false);
#endif
connect(ui->btnSaveAs, SIGNAL(clicked()), ui->lblQRCode, SLOT(saveImage()));
genCode();
}
2013-10-16 15:14:26 +02:00
ReceiveRequestDialog::~ReceiveRequestDialog()
{
delete ui;
}
2013-10-16 15:14:26 +02:00
void ReceiveRequestDialog::setModel(OptionsModel *model)
{
this->model = model;
if (model)
connect(model, SIGNAL(displayUnitChanged(int)), this, SLOT(updateDisplayUnit()));
// update the display unit, to not use the default ("BTC")
updateDisplayUnit();
}
2013-10-16 15:14:26 +02:00
void ReceiveRequestDialog::genCode()
2012-02-15 13:14:16 +01:00
{
QString uri = GUIUtil::formatBitcoinURI(info);
2013-10-16 15:14:26 +02:00
ui->btnSaveAs->setEnabled(false);
ui->outUri->setPlainText(uri);
2013-10-16 15:14:26 +02:00
#ifdef USE_QRCODE
ui->lblQRCode->setText("");
if(!uri.isEmpty())
{
// limit URI length
if (uri.length() > MAX_URI_LENGTH)
{
ui->lblQRCode->setText(tr("Resulting URI too long, try to reduce the text for label / message."));
} else {
QRcode *code = QRcode_encodeString(uri.toUtf8().constData(), 0, QR_ECLEVEL_L, QR_MODE_8, 1);
if (!code)
{
ui->lblQRCode->setText(tr("Error encoding URI into QR Code."));
return;
}
QImage myImage = QImage(code->width + 8, code->width + 8, QImage::Format_RGB32);
myImage.fill(0xffffff);
unsigned char *p = code->data;
for (int y = 0; y < code->width; y++)
{
for (int x = 0; x < code->width; x++)
{
myImage.setPixel(x + 4, y + 4, ((*p & 1) ? 0x0 : 0xffffff));
p++;
}
}
QRcode_free(code);
ui->lblQRCode->setPixmap(QPixmap::fromImage(myImage).scaled(300, 300));
ui->btnSaveAs->setEnabled(true);
}
}
2013-10-16 15:14:26 +02:00
#endif
}
2013-10-16 15:14:26 +02:00
void ReceiveRequestDialog::on_lnReqAmount_textChanged()
2012-02-15 13:14:16 +01:00
{
genCode();
}
2013-10-16 15:14:26 +02:00
void ReceiveRequestDialog::on_lnLabel_textChanged()
2012-02-15 13:14:16 +01:00
{
genCode();
}
2013-10-16 15:14:26 +02:00
void ReceiveRequestDialog::on_lnMessage_textChanged()
2012-02-15 13:14:16 +01:00
{
genCode();
}
2013-10-16 15:14:26 +02:00
void ReceiveRequestDialog::updateDisplayUnit()
{
if (model)
{
// Update lnReqAmount with the current unit
ui->lnReqAmount->setDisplayUnit(model->getDisplayUnit());
}
}