0.5.0 Added beads config. /JL

This commit is contained in:
2022-12-29 23:25:42 +01:00
parent 818f11abdf
commit b14275687d
4 changed files with 183 additions and 2 deletions

View File

@@ -122,7 +122,7 @@ func NewBeadColor(mw *MyMainWindow, name string, id int, red byte, green byte, b
cm, _ := walk.NewComposite(mw.colors)
cm.SetAlignment(walk.AlignHNearVCenter)
hb := walk.NewHBoxLayout()
hb.SetMargins(walk.Margins{5, 0, 20, 0})
hb.SetMargins(walk.Margins{5, 5, 20, 5})
cm.SetLayout(hb)
color := new(BeadColor)
color.Color = cm

View File

@@ -54,6 +54,27 @@ func SetConfigScale(s string) {
Config.SaveWithDelimiter(UserPath+Sep+ConfigFile, "=")
}
func SetConfigShowAll(s string) {
log.Printf("Setting showall to: %s\n", s)
Config, _ := configparser.Parse(UserPath + Sep + ConfigFile)
Config.Set("beads", "showall", s)
Config.SaveWithDelimiter(UserPath+Sep+ConfigFile, "=")
}
func SetConfigGreyscale(s string) {
log.Printf("Setting greyscale to: %s\n", s)
Config, _ := configparser.Parse(UserPath + Sep + ConfigFile)
Config.Set("beads", "greyscale", s)
Config.SaveWithDelimiter(UserPath+Sep+ConfigFile, "=")
}
func SetConfigInStock(s string) {
log.Printf("Setting instock to: %s\n", s)
Config, _ := configparser.Parse(UserPath + Sep + ConfigFile)
Config.Set("beads", "instock", s)
Config.SaveWithDelimiter(UserPath+Sep+ConfigFile, "=")
}
func ReadConfig() {
log.Printf("Reading config file: %s\n", ConfigFile)
Config, _ = configparser.Parse(UserPath + Sep + ConfigFile)
@@ -65,6 +86,9 @@ func ReadConfig() {
ConfogGridColor, _ = Config.Get("canvas", "gridcolor")
ConfigShowBeads, _ = Config.Get("canvas", "showbeads")
ConfigBackgroundColor, _ = Config.Get("canvas", "backgroundcolor")
ConfigShowAll, _ = Config.Get("beads", "showall")
ConfigGreyscale, _ = Config.Get("beads", "greyscale")
ConfigInStock, _ = Config.Get("beads", "instock")
}
func CheckConfigFile() bool {
@@ -89,5 +113,9 @@ func CreateDefaultConfig() {
Config.Set("canvas", "gridcolor", "#00ff00")
Config.Set("canvas", "showbeads", "false")
Config.Set("canvas", "backgroundcolor", "#ffffff")
Config.AddSection("beads")
Config.Set("beads", "showall", "true")
Config.Set("beads", "greyscale", "false")
Config.Set("beads", "instock", "false")
Config.SaveWithDelimiter(UserPath+Sep+ConfigFile, "=")
}

View File

@@ -32,7 +32,7 @@ type MyMainWindow struct {
const (
AppName string = "BeadImager"
Version string = "0.4.5"
Version string = "0.5.0"
CopyRight string = "©2022 Jan Lerking"
STD_MESS string = "Ready"
LogFile string = "BeadImager.log"
@@ -49,6 +49,9 @@ var (
ConfogGridColor string
ConfigShowBeads string
ConfigBackgroundColor string
ConfigShowAll string
ConfigGreyscale string
ConfigInStock string
)
func SetupMainWindow(mw *MyMainWindow) {

View File

@@ -13,6 +13,7 @@ type (
propColor *PropColor
propScale *PropScale
propCanvas *PropCanvas
propBeads *PropBeads
}
PropColor struct {
@@ -28,6 +29,14 @@ type (
property *walk.Composite
visible bool
}
PropBeads struct {
property *walk.Composite
showAll *walk.RadioButton
greyScale *walk.RadioButton
inStock *walk.CheckBox
visible bool
}
)
func CreateProperties(mw *MyMainWindow) {
@@ -35,6 +44,7 @@ func CreateProperties(mw *MyMainWindow) {
mw.properties.propColor = new(PropColor)
mw.properties.propScale = new(PropScale)
mw.properties.propCanvas = new(PropCanvas)
mw.properties.propBeads = new(PropBeads)
CreateSettingsGroup(mw)
}
@@ -88,6 +98,7 @@ func CreateSettingsGroup(mw *MyMainWindow) {
CreateColorProperties(mw)
CreateScaleProperties(mw)
CreateCanvasProperties(mw)
CreateBeadsProperties(mw)
}
func CreateColorProperties(mw *MyMainWindow) {
@@ -342,3 +353,142 @@ func CreateCanvasProperties(mw *MyMainWindow) {
}
mw.properties.propCanvas.property.SetBackground(bg)
}
func CreateBeadsProperties(mw *MyMainWindow) {
var err error
mw.properties.propBeads.property, err = walk.NewComposite(mw.propScroll)
if err != nil {
log.Println("Error creating beads property: ", err)
}
err = mw.properties.propBeads.property.SetAlignment(walk.AlignHNearVNear)
if err != nil {
log.Println("Error setting beads property alignment: ", err)
}
vb := walk.NewVBoxLayout()
err = mw.properties.propBeads.property.SetLayout(vb)
if err != nil {
log.Println("Error setting beads property layout: ", err)
}
lbl, err := walk.NewTextLabel(mw.properties.propBeads.property)
if err != nil {
log.Println("Error creating beads label: ", err)
}
err = lbl.SetText("Beads: ")
if err != nil {
log.Println("Error setting beads label text: ", err)
}
grcom, err := walk.NewComposite(mw.properties.propBeads.property)
if err != nil {
log.Println("Error creating beads group: ", err)
}
err = grcom.SetAlignment(walk.AlignHNearVNear)
if err != nil {
log.Println("Error setting beads group alignment: ", err)
}
hb := walk.NewHBoxLayout()
err = hb.SetMargins(walk.Margins{0, 0, 0, 0})
if err != nil {
log.Println("Error setting beads group margins: ", err)
}
err = grcom.SetLayout(hb)
if err != nil {
log.Println("Error setting beads group layout: ", err)
}
mw.properties.propBeads.showAll, err = walk.NewRadioButton(grcom)
if err != nil {
log.Println("Error creating beads checkbox: ", err)
}
err = mw.properties.propBeads.showAll.SetAlignment(walk.AlignHNearVNear)
if err != nil {
log.Println("Error setting beads checkbox alignment: ", err)
}
err = mw.properties.propBeads.showAll.SetText("Show all")
if err != nil {
log.Println("Error setting beads checkbox text: ", err)
}
switch ConfigShowAll {
case "true":
mw.properties.propBeads.showAll.SetChecked(true)
case "false":
mw.properties.propBeads.showAll.SetChecked(false)
}
mw.properties.propBeads.showAll.CheckedChanged().Attach(func() {
log.Println("Show all changed")
if mw.properties.propBeads.showAll.Checked() && mw.properties.propBeads.greyScale.Checked() {
mw.properties.propBeads.greyScale.SetChecked(false)
}
if !mw.properties.propBeads.showAll.Checked() {
SetConfigShowAll("false")
mw.properties.propBeads.greyScale.SetChecked(true)
} else {
SetConfigShowAll("true")
mw.properties.propBeads.greyScale.SetChecked(false)
}
})
walk.NewHSpacer(grcom)
mw.properties.propBeads.greyScale, err = walk.NewRadioButton(grcom)
if err != nil {
log.Println("Error creating pixels checkbox: ", err)
}
err = mw.properties.propBeads.greyScale.SetAlignment(walk.AlignHNearVNear)
if err != nil {
log.Println("Error setting pixels checkbox alignment: ", err)
}
err = mw.properties.propBeads.greyScale.SetText("Greyscale")
if err != nil {
log.Println("Error setting pixels checkbox text: ", err)
}
switch ConfigGreyscale {
case "true":
mw.properties.propBeads.greyScale.SetChecked(true)
case "false":
mw.properties.propBeads.greyScale.SetChecked(false)
}
mw.properties.propBeads.greyScale.CheckedChanged().Attach(func() {
log.Println("Greyscale changed")
if mw.properties.propBeads.showAll.Checked() && mw.properties.propBeads.greyScale.Checked() {
mw.properties.propBeads.showAll.SetChecked(false)
}
if !mw.properties.propBeads.greyScale.Checked() {
SetConfigGreyscale("false")
mw.properties.propBeads.showAll.SetChecked(true)
} else {
SetConfigGreyscale("true")
mw.properties.propBeads.showAll.SetChecked(false)
}
})
mw.properties.propBeads.inStock, err = walk.NewCheckBox(mw.properties.propBeads.property)
if err != nil {
log.Println("Error creating pixels checkbox: ", err)
}
err = mw.properties.propBeads.inStock.SetAlignment(walk.AlignHNearVNear)
if err != nil {
log.Println("Error setting pixels checkbox alignment: ", err)
}
err = mw.properties.propBeads.inStock.SetText("Show only beads in stock")
if err != nil {
log.Println("Error setting pixels checkbox text: ", err)
}
switch ConfigInStock {
case "true":
mw.properties.propBeads.inStock.SetChecked(true)
case "false":
mw.properties.propBeads.inStock.SetChecked(false)
}
mw.properties.propBeads.inStock.CheckedChanged().Attach(func() {
log.Println("In stock changed")
if mw.properties.propBeads.showAll.Checked() && mw.properties.propBeads.greyScale.Checked() {
mw.properties.propBeads.greyScale.SetChecked(false)
}
if mw.properties.propBeads.inStock.Checked() {
SetConfigInStock("true")
} else {
SetConfigInStock("false")
}
})
bg, err := walk.NewSolidColorBrush(walk.RGB(255, 255, 255))
if err != nil {
log.Println("Error creating beads brush: ", err)
}
mw.properties.propBeads.property.SetBackground(bg)
}