diff options
author | obscuren <geffobscura@gmail.com> | 2014-06-24 15:39:25 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2014-06-24 15:39:25 +0800 |
commit | a13aa873c205f35d3d90adf9da4c6355499fff1b (patch) | |
tree | fc7b241407a121702e0bea03e1a65cabf8b2b8b6 /ethereal/ui/qml_app.go | |
parent | 17e8d7519b1aac322db08b857e63db82a322d6cf (diff) | |
parent | bcb88e73528777ac0de489449a8d9045654447d5 (diff) | |
download | dexon-a13aa873c205f35d3d90adf9da4c6355499fff1b.tar dexon-a13aa873c205f35d3d90adf9da4c6355499fff1b.tar.gz dexon-a13aa873c205f35d3d90adf9da4c6355499fff1b.tar.bz2 dexon-a13aa873c205f35d3d90adf9da4c6355499fff1b.tar.lz dexon-a13aa873c205f35d3d90adf9da4c6355499fff1b.tar.xz dexon-a13aa873c205f35d3d90adf9da4c6355499fff1b.tar.zst dexon-a13aa873c205f35d3d90adf9da4c6355499fff1b.zip |
Merge branch 'develop' of github.com-obscure:ethereum/go-ethereum into develop
Diffstat (limited to 'ethereal/ui/qml_app.go')
-rw-r--r-- | ethereal/ui/qml_app.go | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/ethereal/ui/qml_app.go b/ethereal/ui/qml_app.go new file mode 100644 index 000000000..d47751616 --- /dev/null +++ b/ethereal/ui/qml_app.go @@ -0,0 +1,59 @@ +package ethui + +import ( + "github.com/ethereum/eth-go/ethchain" + "github.com/ethereum/eth-go/ethpub" + "github.com/ethereum/eth-go/ethutil" + "github.com/go-qml/qml" +) + +type QmlApplication struct { + win *qml.Window + engine *qml.Engine + lib *UiLib + path string +} + +func NewQmlApplication(path string, lib *UiLib) *QmlApplication { + engine := qml.NewEngine() + return &QmlApplication{engine: engine, path: path, lib: lib} +} + +func (app *QmlApplication) Create() error { + component, err := app.engine.LoadFile(app.path) + if err != nil { + ethutil.Config.Log.Debugln(err) + } + app.win = component.CreateWindow(nil) + + return nil +} + +func (app *QmlApplication) Destroy() { + app.engine.Destroy() +} + +func (app *QmlApplication) NewWatcher(quitChan chan bool) { +} + +// Events +func (app *QmlApplication) NewBlock(block *ethchain.Block) { + pblock := ðpub.PBlock{Number: int(block.BlockInfo().Number), Hash: ethutil.Hex(block.Hash())} + app.win.Call("onNewBlockCb", pblock) +} + +func (app *QmlApplication) ObjectChanged(stateObject *ethchain.StateObject) { + app.win.Call("onObjectChangeCb", ethpub.NewPStateObject(stateObject)) +} + +func (app *QmlApplication) StorageChanged(storageObject *ethchain.StorageState) { + app.win.Call("onStorageChangeCb", ethpub.NewPStorageState(storageObject)) +} + +// Getters +func (app *QmlApplication) Engine() *qml.Engine { + return app.engine +} +func (app *QmlApplication) Window() *qml.Window { + return app.win +} |