summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKevin Chabowski <kevin@kch42.de>2013-11-04 13:20:13 +0100
committerKevin Chabowski <kevin@kch42.de>2013-11-04 13:20:13 +0100
commitc14bae386dc7a8db6dc1dd81facce8e317aa45f9 (patch)
tree38ac5363575fdcb9d2845c54fe09d4ebb9124863
parent69902644f31689a3f9e19c950718ced8a462494b (diff)
downloadbiomed-c14bae386dc7a8db6dc1dd81facce8e317aa45f9.tar.gz
biomed-c14bae386dc7a8db6dc1dd81facce8e317aa45f9.tar.bz2
biomed-c14bae386dc7a8db6dc1dd81facce8e317aa45f9.zip
Adding, deleting and modifying biomes works!
-rw-r--r--biome_info_editor.go83
1 files changed, 79 insertions, 4 deletions
diff --git a/biome_info_editor.go b/biome_info_editor.go
index 27c18ef..80f893c 100644
--- a/biome_info_editor.go
+++ b/biome_info_editor.go
@@ -15,6 +15,7 @@ type biomeEditFrame struct {
applyBtn *gtk.Button
idInput, snowLineInput, nameInput *gtk.Entry
colorInput *gtk.ColorButton
+ bList *biomeList
}
func newBiomeEditFrame() *biomeEditFrame {
@@ -51,6 +52,8 @@ func newBiomeEditFrame() *biomeEditFrame {
vbox.PackStart(frm.applyBtn, false, false, 3)
frm.Add(vbox)
+ frm.applyBtn.Connect("clicked", frm.doApply)
+
return frm
}
@@ -61,6 +64,15 @@ func (frm *biomeEditFrame) setBiomeInfo(info BiomeInfo) {
frm.nameInput.SetText(info.Name)
}
+func (frm *biomeEditFrame) doApply() {
+ biome, ok := frm.getBiomeInfo()
+ if !ok {
+ return
+ }
+
+ frm.bList.setCurrentBiome(biome)
+}
+
func (frm *biomeEditFrame) getBiomeInfo() (BiomeInfo, bool) {
id, err := strconv.ParseUint(frm.idInput.GetText(), 10, 8)
if err != nil {
@@ -86,7 +98,7 @@ func (frm *biomeEditFrame) getBiomeInfo() (BiomeInfo, bool) {
ID: mcmap.Biome(id),
SnowLine: int(snow),
Name: name,
- Color: fmt.Sprintf("#%02x%02x%02x", col.Red()<<8, col.Green()<<8, col.Blue()<<8),
+ Color: fmt.Sprintf("#%02x%02x%02x", col.Red()>>8, col.Green()>>8, col.Blue()>>8),
}, true
}
@@ -104,6 +116,7 @@ type biomeList struct {
treeview *gtk.TreeView
lStore *gtk.ListStore
biomes []BiomeInfo
+ editfrm *biomeEditFrame
}
func newBiomeList() *biomeList {
@@ -124,6 +137,7 @@ func newBiomeList() *biomeList {
bl.treeview.AppendColumn(gtk.NewTreeViewColumnWithAttributes("Snowline", gtk.NewCellRendererText(), "text", 2))
bl.treeview.AppendColumn(gtk.NewTreeViewColumnWithAttributes("Name", gtk.NewCellRendererText(), "text", 3))
+ bl.treeview.GetSelection().SetMode(gtk.SELECTION_SINGLE)
bl.treeview.Connect("cursor-changed", bl.onCursorChanged)
vbox := gtk.NewVBox(false, 0)
@@ -156,6 +170,15 @@ func (bl *biomeList) setBiome(iter *gtk.TreeIter, biome BiomeInfo) {
bl.lStore.Set(iter, biome.Color, strconv.FormatInt(int64(biome.ID), 10), strconv.FormatInt(int64(biome.SnowLine), 10), biome.Name)
}
+func (bl *biomeList) setCurrentBiome(biome BiomeInfo) {
+ idx, iter := bl.treeviewIdx()
+ if idx < 0 {
+ return
+ }
+ bl.biomes[idx] = biome
+ bl.setBiome(iter, biome)
+}
+
func (bl *biomeList) SetBiomes(biomes []BiomeInfo) {
bl.biomes = biomes
@@ -169,15 +192,66 @@ func (bl *biomeList) SetBiomes(biomes []BiomeInfo) {
func (bl *biomeList) Biomes() []BiomeInfo { return bl.biomes }
+func (bl *biomeList) treeviewIdx() (int, *gtk.TreeIter) {
+ var path *gtk.TreePath
+ var column *gtk.TreeViewColumn
+ bl.treeview.GetCursor(&path, &column)
+
+ idxs := path.GetIndices()
+ if len(idxs) != 1 {
+ return -1, nil
+ }
+ var iter gtk.TreeIter
+ bl.lStore.GetIter(&iter, path)
+
+ return idxs[0], &iter
+}
+
func (bl *biomeList) onCursorChanged() {
- // TODO
+ idx, _ := bl.treeviewIdx()
+ if idx < 0 {
+ return
+ }
+
+ bl.editfrm.setBiomeInfo(bl.biomes[idx])
+}
+
+func (bl *biomeList) onAdd() {
+ bio := BiomeInfo{
+ Color: "#000000",
+ ID: 0,
+ SnowLine: 255,
+ Name: "(new)",
+ }
+ bl.biomes = append(bl.biomes, bio)
+
+ var iter gtk.TreeIter
+ bl.lStore.Append(&iter)
+ bl.setBiome(&iter, bio)
+ path := gtk.NewTreePath()
+ path.AppendIndex(len(bl.biomes) - 1)
+ bl.treeview.SetCursor(path, nil, false)
}
-func (bl *biomeList) onAdd() {} // TODO
-func (bl *biomeList) onDel() {} // TODO
+func (bl *biomeList) onDel() {
+ idx, iter := bl.treeviewIdx()
+ if idx < 0 {
+ return
+ }
+
+ copy(bl.biomes[idx:], bl.biomes[idx+1:])
+ bl.biomes = bl.biomes[:len(bl.biomes)-1]
+
+ bl.lStore.Remove(iter)
+}
func (bl *biomeList) onUp() {} // TODO
func (bl *biomeList) onDown() {} // TODO
+func connectBiomeListEditFrame(bl *biomeList, frm *biomeEditFrame) {
+ bl.editfrm = frm
+ frm.bList = bl
+}
+
type BiomeInfoEditor struct {
*gtk.Dialog
biolist *biomeList
@@ -211,6 +285,7 @@ func NewBiomeInfoEditor(biomes []BiomeInfo) *BiomeInfoEditor {
vbox.PackStart(ed.biolist, true, true, 3)
editFrame := newBiomeEditFrame()
+ connectBiomeListEditFrame(ed.biolist, editFrame)
vbox.PackStart(editFrame, false, false, 3)
ed.AddButton("Cancel", gtk.RESPONSE_CANCEL)