Example documented class
This commit is contained in:
parent
15ceadf7a5
commit
66112ed6e6
1 changed files with 43 additions and 13 deletions
|
@ -24,6 +24,10 @@ class QStackedWidget;
|
||||||
class QUrl;
|
class QUrl;
|
||||||
QT_END_NAMESPACE
|
QT_END_NAMESPACE
|
||||||
|
|
||||||
|
/**
|
||||||
|
Bitcoin GUI main class. This class represents the main window of the Bitcoin UI. It communicates with both the client and
|
||||||
|
wallet models to give the user an up-to-date view of the current core state.
|
||||||
|
*/
|
||||||
class BitcoinGUI : public QMainWindow
|
class BitcoinGUI : public QMainWindow
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
@ -31,17 +35,16 @@ public:
|
||||||
explicit BitcoinGUI(QWidget *parent = 0);
|
explicit BitcoinGUI(QWidget *parent = 0);
|
||||||
~BitcoinGUI();
|
~BitcoinGUI();
|
||||||
|
|
||||||
|
/** Set the client model.
|
||||||
|
The client model represents the part of the core that communicates with the P2P network, and is wallet-agnostic.
|
||||||
|
*/
|
||||||
void setClientModel(ClientModel *clientModel);
|
void setClientModel(ClientModel *clientModel);
|
||||||
|
/** Set the wallet model.
|
||||||
|
The wallet model represents a bitcoin wallet, and offers access to the list of transactions, address book and sending
|
||||||
|
functionality.
|
||||||
|
*/
|
||||||
void setWalletModel(WalletModel *walletModel);
|
void setWalletModel(WalletModel *walletModel);
|
||||||
|
|
||||||
/* Transaction table tab indices */
|
|
||||||
enum {
|
|
||||||
AllTransactions = 0,
|
|
||||||
SentReceived = 1,
|
|
||||||
Sent = 2,
|
|
||||||
Received = 3
|
|
||||||
} TabIndex;
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void changeEvent(QEvent *e);
|
void changeEvent(QEvent *e);
|
||||||
void closeEvent(QCloseEvent *event);
|
void closeEvent(QCloseEvent *event);
|
||||||
|
@ -86,41 +89,68 @@ private:
|
||||||
|
|
||||||
QMovie *syncIconMovie;
|
QMovie *syncIconMovie;
|
||||||
|
|
||||||
|
/** Create the main UI actions. */
|
||||||
void createActions();
|
void createActions();
|
||||||
|
/** Create the menu bar and submenus. */
|
||||||
void createMenuBar();
|
void createMenuBar();
|
||||||
|
/** Create the toolbars */
|
||||||
void createToolBars();
|
void createToolBars();
|
||||||
QWidget *createTabs();
|
/** Create system tray (notification) icon */
|
||||||
void createTrayIcon();
|
void createTrayIcon();
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
|
/** Set number of connections shown in the UI */
|
||||||
void setNumConnections(int count);
|
void setNumConnections(int count);
|
||||||
|
/** Set number of blocks shown in the UI */
|
||||||
void setNumBlocks(int count);
|
void setNumBlocks(int count);
|
||||||
|
/** Set the encryption status as shown in the UI.
|
||||||
|
@param[in] status current encryption status
|
||||||
|
@see WalletModel::EncryptionStatus
|
||||||
|
*/
|
||||||
void setEncryptionStatus(int status);
|
void setEncryptionStatus(int status);
|
||||||
|
|
||||||
|
/** Notify the user of an error in the network or transaction handling code. */
|
||||||
void error(const QString &title, const QString &message);
|
void error(const QString &title, const QString &message);
|
||||||
/* It is currently not possible to pass a return value to another thread through
|
/** Asks the user whether to pay the transaction fee or to cancel the transaction.
|
||||||
BlockingQueuedConnection, so use an indirected pointer.
|
It is currently not possible to pass a return value to another thread through
|
||||||
|
BlockingQueuedConnection, so an indirected pointer is used.
|
||||||
http://bugreports.qt.nokia.com/browse/QTBUG-10440
|
http://bugreports.qt.nokia.com/browse/QTBUG-10440
|
||||||
|
|
||||||
|
@param[in] nFeeRequired the required fee
|
||||||
|
@param[out] payFee true to pay the fee, false to not pay the fee
|
||||||
*/
|
*/
|
||||||
void askFee(qint64 nFeeRequired, bool *payFee);
|
void askFee(qint64 nFeeRequired, bool *payFee);
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
// UI pages
|
/** Switch to overview (home) page */
|
||||||
void gotoOverviewPage();
|
void gotoOverviewPage();
|
||||||
|
/** Switch to history (transactions) page */
|
||||||
void gotoHistoryPage();
|
void gotoHistoryPage();
|
||||||
|
/** Switch to address book page */
|
||||||
void gotoAddressBookPage();
|
void gotoAddressBookPage();
|
||||||
|
/** Switch to receive coins page */
|
||||||
void gotoReceiveCoinsPage();
|
void gotoReceiveCoinsPage();
|
||||||
|
/** Switch to send coins page */
|
||||||
void gotoSendCoinsPage();
|
void gotoSendCoinsPage();
|
||||||
|
|
||||||
// Misc actions
|
/** Show configuration dialog */
|
||||||
void optionsClicked();
|
void optionsClicked();
|
||||||
|
/** Show about dialog */
|
||||||
void aboutClicked();
|
void aboutClicked();
|
||||||
#ifndef Q_WS_MAC
|
#ifndef Q_WS_MAC
|
||||||
|
/** Handle tray icon clicked */
|
||||||
void trayIconActivated(QSystemTrayIcon::ActivationReason reason);
|
void trayIconActivated(QSystemTrayIcon::ActivationReason reason);
|
||||||
#endif
|
#endif
|
||||||
|
/** Show incoming transaction notification for new transactions.
|
||||||
|
|
||||||
|
The new items are those between start and end inclusive, under the given parent item.
|
||||||
|
*/
|
||||||
void incomingTransaction(const QModelIndex & parent, int start, int end);
|
void incomingTransaction(const QModelIndex & parent, int start, int end);
|
||||||
|
/** Encrypt the wallet */
|
||||||
void encryptWallet(bool status);
|
void encryptWallet(bool status);
|
||||||
|
/** Change encrypted wallet passphrase */
|
||||||
void changePassphrase();
|
void changePassphrase();
|
||||||
|
/** Ask for pass phrase to unlock wallet temporarily */
|
||||||
void unlockWallet();
|
void unlockWallet();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue