Example documented class

This commit is contained in:
Wladimir J. van der Laan 2011-11-13 11:12:33 +01:00
parent 15ceadf7a5
commit 66112ed6e6

View File

@ -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();
}; };