Implement icon resizing.
[drlaunch] / src / config.py
index a7520af..ac61424 100755 (executable)
@@ -25,7 +25,7 @@ __version__ = "$Id: 0.py 2265 2010-02-21 19:16:26Z v13 $"
 import os
 import pickle
 
-version = "0.3"
+version = "1.0"
 
 try:
     from glib import get_user_config_dir
@@ -59,26 +59,71 @@ class Config:
        self.id=id
 
        self.size = (2,2)
-       self.iconsize = 64
-       self.iconspace = 42
+       self.themebgsize = 96
+       self.iconsize0 = 64
+###    self.iconspace = 42     # For 4 icons (height)
+##     self.iconspace = 36     # For 8 icons (width)
+
+#      self.iconsize = 64
+#      self.iconpadding = 12
+#      self.iconmargin = 6
+
        self.apps=None
-       self.indiv=False
-       self.longpress=True
+       self.indiv=True
+       self.longpress=False
+       self.animate=True
+       self.nobg=False
+       self.themebg=False
+
+       self.setDefaultSizes()
 
-       self.maxsz=(4,4)
+       #self.maxsz=(8,4)
 
     def setSize(self, sz):
-       self.size=sz
+       maxsz=self.getMaxSize()
+       sz2=(min(sz[0], maxsz[0]), min(sz[1], maxsz[1]))
+       self.size=sz2
 
     def getSize(self):
        return(self.size)
 
+    def setDefaultSizes(self):
+       self.iconsize=64
+       self.iconpadding=12
+       self.iconmargin=6
+
     def getMaxSize(self):
-       return(self.maxsz)
+       isf=self.getIconSizeFull()
+       retx=int(800/isf)
+       rety=int((480-60)/isf)
+       maxsz=(retx, rety)
+       return(maxsz)
 
     def getIconSize(self):
        return(self.iconsize)
 
+    def setIconSize(self, sz):
+       self.iconsize=sz
+
+    def getIconSpace(self):
+       return((2*self.iconpadding) + (2*self.iconmargin))
+
+    def getIconSizeFull(self):
+       ret=self.iconsize + (2*self.iconpadding) + (2*self.iconmargin)
+       return(ret)
+
+    def getIconMargin(self):
+       return(self.iconmargin)
+
+    def setIconMargin(self, sz):
+       self.iconmargin=sz
+
+    def getIconPadding(self):
+       return(self.iconpadding)
+
+    def setIconPadding(self, sz):
+       self.iconpadding=sz
+
     def setIndiv(self, indiv):
        self.indiv=indiv
 
@@ -91,6 +136,24 @@ class Config:
     def getLongpress(self):
        return(self.longpress)
 
+    def setAnimate(self, ar):
+       self.animate=ar
+
+    def getAnimate(self):
+       return(self.animate)
+
+    def setNoBg(self, nobg):
+       self.nobg=nobg
+
+    def getNoBg(self):
+       return(self.nobg)
+
+    def setThemeBg(self, themebg):
+       self.themebg=themebg
+
+    def getThemeBg(self):
+       return(self.themebg)
+
     def setApps(self, aps):
        """ apps is a dictionary of (x,y)=>appname """
        self.apps=aps
@@ -107,6 +170,18 @@ class Config:
 
        return(self.apps)
 
+    def filterDefault(self, value, default):
+       if value==default:
+           return(-1)
+       else:
+           return(value)
+
+    def provideDefault(self, value, default):
+       if value==-1:
+           return(default)
+       else:
+           return(value)
+
     def save(self):
        self.check_init()
 
@@ -114,7 +189,7 @@ class Config:
 
        if dt==None:
            dt={
-               'version':  3,
+               'version':  7,
                'data': {},
                }
 
@@ -123,6 +198,12 @@ class Config:
            'apps':         self.getApps(),
            'indiv':        self.getIndiv(),
            'longpress':    self.getLongpress(),
+           'animate':      self.getAnimate(),
+           'nobg':         self.getNoBg(),
+           'themebg':      self.getThemeBg(),
+           'iconsize':     self.filterDefault(self.getIconSize(), 64),
+           'iconpadding':  self.filterDefault(self.getIconPadding(), 12),
+           'iconmargin':   self.filterDefault(self.getIconMargin(), 6),
            }
 
        fn=get_config_fn()
@@ -158,6 +239,40 @@ class Config:
 
        return(dt)
 
+    def parse_v3(self, dt):
+       dt['version']=4
+
+       for i in dt['data']:
+           dt['data'][i]['animate']=True
+
+       return(dt)
+
+    def parse_v4(self, dt):
+       dt['version']=5
+
+       for i in dt['data']:
+           dt['data'][i]['nobg']=False
+
+       return(dt)
+
+    def parse_v5(self, dt):
+       dt['version']=6
+
+       for i in dt['data']:
+           dt['data'][i]['themebg']=False
+
+       return(dt)
+
+    def parse_v6(self, dt):
+       dt['version']=7
+
+       for i in dt['data']:
+           dt['data'][i]['iconsize']=-1
+           dt['data'][i]['iconpadding']=-1
+           dt['data'][i]['iconmargin']=-1
+
+       return(dt)
+
     def load_all(self):
        fn=get_config_fn()
 
@@ -168,14 +283,28 @@ class Config:
            ret=pickle.loads(st)
 
            if ret==None:
+               print "failed to load config"
                ret=None
            else:
                if ret['version']==1:
-                   ret=parse_v1(ret)
+                   ret=self.parse_v1(ret)
 
                if ret['version']==2:
-                   ret=parse_v2(ret)
-       except:
+                   ret=self.parse_v2(ret)
+
+               if ret['version']==3:
+                   ret=self.parse_v3(ret)
+
+               if ret['version']==4:
+                   ret=self.parse_v4(ret)
+
+               if ret['version']==5:
+                   ret=self.parse_v5(ret)
+
+               if ret['version']==6:
+                   ret=self.parse_v6(ret)
+       except Exception, e:
+           print "config error:", e
            ret=None
 
        return(ret)
@@ -196,6 +325,12 @@ class Config:
        self.setApps(dt['apps'])
        self.setIndiv(dt['indiv'])
        self.setLongpress(dt['longpress'])
+       self.setAnimate(dt['animate'])
+       self.setNoBg(dt['nobg'])
+       self.setThemeBg(dt['themebg'])
+       self.setIconSize(self.provideDefault(dt['iconsize'], 64))
+       self.setIconPadding(self.provideDefault(dt['iconpadding'], 12))
+       self.setIconMargin(self.provideDefault(dt['iconmargin'], 6))
 
     def check_init(self):
        if self.id==None: