123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170 |
- """!
- @package gui_core.query
- @brief wxGUI query dialog
- Classes:
- - query::QueryDialog
- (C) 2013 by the GRASS Development Team
- This program is free software under the GNU General Public License
- (>=v2). Read the file COPYING that comes with GRASS for details.
- @author Anna Kratochvilova <kratochanna gmail.com>
- """
- import os
- import sys
- import random
- import wx
- if __name__ == '__main__':
- sys.path.append(os.path.join(os.environ['GISBASE'], "etc", "gui", "wxpython"))
- from gui_core.treeview import TreeListView
- from core.treemodel import TreeModel, DictNode
- class QueryDialog(wx.Dialog):
- def __init__(self, parent, data = None):
- wx.Dialog.__init__(self, parent, id = wx.ID_ANY,
- title = _("Query results"),
- size = (420, 400),
- style = wx.DEFAULT_DIALOG_STYLE | wx.RESIZE_BORDER)
- self.data = data
- self.panel = wx.Panel(self, id = wx.ID_ANY)
- self.mainSizer = wx.BoxSizer(wx.VERTICAL)
- self._colNames = [_("Feature"), _("Value")]
- self._model = QueryTreeBuilder(self.data, column=self._colNames[1])
- self.tree = TreeListView(model=self._model, parent=self.panel,
- columns=self._colNames,
- style=wx.TR_DEFAULT_STYLE |
- wx.TR_FULL_ROW_HIGHLIGHT | wx.TR_MULTIPLE)
- self.tree.SetColumnWidth(0, 220)
- self.tree.SetColumnWidth(1, 400)
- self.tree.ExpandAll(self._model.root)
- self.mainSizer.Add(item = self.tree, proportion = 1, flag = wx.EXPAND | wx.ALL, border = 5)
- close = wx.Button(self.panel, id = wx.ID_CLOSE)
- close.Bind(wx.EVT_BUTTON, lambda event: self.Close())
- copy = wx.Button(self.panel, id = wx.ID_ANY, label = _("Copy to clipboard"))
- copy.Bind(wx.EVT_BUTTON, self.Copy)
- self.Bind(wx.EVT_CLOSE, self.OnClose)
- hbox = wx.BoxSizer(wx.HORIZONTAL)
- hbox.AddStretchSpacer(1)
- hbox.Add(item = copy, proportion = 0, flag = wx.EXPAND | wx.RIGHT, border = 5)
- hbox.Add(item = close, proportion = 0, flag = wx.EXPAND | wx.ALL, border = 0)
- self.mainSizer.Add(item = hbox, proportion = 0, flag = wx.EXPAND | wx.ALL, border = 5)
- self.panel.SetSizer(self.mainSizer)
- self.mainSizer.Fit(self.panel)
- # for Windows
- self.SendSizeEvent()
- def SetData(self, data):
- state = self.tree.GetExpansionState()
- self.data = data
- self._model = QueryTreeBuilder(self.data, column=self._colNames[1])
- self.tree.SetModel(self._model)
- self.tree.SetExpansionState(state)
- def Copy(self, event):
- text = printResults(self._model, self._colNames[1])
- if wx.TheClipboard.Open():
- do = wx.TextDataObject()
- do.SetText(text)
- wx.TheClipboard.SetData(do)
- wx.TheClipboard.Close()
- def OnClose(self, event):
- self.Destroy()
- event.Skip()
- def QueryTreeBuilder(data, column):
- """!Builds tree model from query results.
-
- @param data query results as a dictionary
- @param column column name
-
- @returns tree model
- """
- def addNode(parent, data, model):
- for k, v in data.iteritems():
- if isinstance(v, dict):
- node = model.AppendNode(parent=parent, label=k)
- addNode(parent=node, data=v, model=model)
- else:
- node = model.AppendNode(parent=parent, label=k,
- data={column: str(v)})
- model = TreeModel(DictNode)
- for part in data:
- addNode(parent=model.root, data=part, model=model)
- return model
- def printResults(model, valueCol):
- """!Print all results to string.
-
- @param model results tree model
- @param valueCol column name with value to be printed
- """
- def printTree(node, textList, valueCol, indent=0):
- textList.append(indent*' ' + node.label + ': ' + node.data.get(valueCol, ''))
- for child in node.children:
- printTree(node=child, textList=textList, valueCol=valueCol, indent=indent + 2)
-
- textList=[]
- for child in model.root.children:
- printTree(node=child, textList=textList, valueCol=valueCol)
- return '\n'.join(textList)
- def PrepareQueryResults(coordinates, result):
- """!Prepare query results as a Query dialog input.
- Adds coordinates, improves vector results tree structure.
- """
- data = []
- data.append({_("east"): coordinates[0]})
- data.append({_("north"): coordinates[1]})
- for part in result:
- if 'Map' in part:
- itemText = part['Map']
- if 'Mapset' in part:
- itemText += '@' + part['Mapset']
- del part['Mapset']
- del part['Map']
- if part:
- data.append({itemText: part})
- else:
- data.append({itemText: _("Nothing found")})
- else:
- data.append(part)
- return data
- def test():
- app = wx.PySimpleApp()
- from grass.script import vector as gvect
- from grass.script import raster as grast
- testdata1 = grast.raster_what(map = ('elevation_shade@PERMANENT','landclass96'),
- coord = [(638509.051416,224742.348346)])
- testdata2 = gvect.vector_what(map=('firestations','bridges'),
- coord=(633177.897487,221352.921257), distance=10)
-
- testdata = testdata1 + testdata2
- data = PrepareQueryResults(coordinates = (638509.051416,224742.348346), result = testdata)
- frame = QueryDialog(parent = None, data = data)
- frame.ShowModal()
- frame.Destroy()
- app.MainLoop()
- if __name__ == "__main__":
- test()
|