diff options
| author | Pietro Gagliardi <[email protected]> | 2014-08-23 19:29:17 -0400 |
|---|---|---|
| committer | Pietro Gagliardi <[email protected]> | 2014-08-23 19:29:17 -0400 |
| commit | 84e7d24a5c3801197f6502c7de42580e67c9db08 (patch) | |
| tree | 9e8457b1470c94439191f9acc26a4e38e636ccb7 /redo/area_darwin.go | |
| parent | 89ea8f5cbb502d0652595993a062ea1a947b50d6 (diff) | |
Fixed a lot of Area.OpenTextFieldAt(); thanks to mikeash in irc.freenode.net/#macdev.
Diffstat (limited to 'redo/area_darwin.go')
| -rw-r--r-- | redo/area_darwin.go | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/redo/area_darwin.go b/redo/area_darwin.go index 4bd5902..83d148e 100644 --- a/redo/area_darwin.go +++ b/redo/area_darwin.go @@ -29,7 +29,8 @@ func newArea(ab *areabase) Area { a._id = C.newArea(unsafe.Pointer(a)) a.scroller = newScroller(a._id, false) // no border on Area a.SetSize(a.width, a.height) - a.textfield = C.newAreaTextField(a._id, unsafe.Pointer(a)) + a.textfield = C.newTextField() + C.areaSetTextField(a._id, a.textfield) return a } @@ -62,7 +63,7 @@ func (a *area) OpenTextFieldAt(x, y int) { if x < 0 || x >= a.width || y < 0 || y >= a.height { panic(fmt.Errorf("point (%d,%d) outside Area in Area.OpenTextFieldAt()", x, y)) } - C.areaTextFieldOpen(a.textfield, C.intptr_t(x), C.intptr_t(y)) + C.areaTextFieldOpen(a._id, a.textfield, C.intptr_t(x), C.intptr_t(y)) } func (a *area) TextFieldText() string { @@ -82,6 +83,8 @@ func (a *area) OnTextFieldDismissed(f func()) { //export areaTextFieldDismissed func areaTextFieldDismissed(data unsafe.Pointer) { a := (*area)(unsafe.Pointer(data)) + // TODO does not work? + C.controlSetHidden(a.textfield, C.YES) a.textfielddone.fire() } |
