Changeset d318616 in sasview for invariantview


Ignore:
Timestamp:
Jul 27, 2010 11:36:25 PM (14 years ago)
Author:
Jae Cho <jhjcho@…>
Branches:
master, ESS_GUI, ESS_GUI_Docs, ESS_GUI_batch_fitting, ESS_GUI_bumps_abstraction, ESS_GUI_iss1116, ESS_GUI_iss879, ESS_GUI_iss959, ESS_GUI_opencl, ESS_GUI_ordering, ESS_GUI_sync_sascalc, costrafo411, magnetic_scatt, release-4.1.1, release-4.1.2, release-4.2.2, release_4.0.1, ticket-1009, ticket-1094-headless, ticket-1242-2d-resolution, ticket-1243, ticket-1249, ticket885, unittest-saveload
Children:
0881f51
Parents:
51fb7ab
Message:

hoped fixed mal-behavior of loading into the panel

Location:
invariantview/perspectives/invariant
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • invariantview/perspectives/invariant/invariant.py

    r51fb7ab rd318616  
    287287            self.parent.set_perspective(self.perspective) 
    288288            # set state 
     289            self.is_state_data = True  
     290            self.invariant_panel.is_state_data = True 
    289291            self.invariant_panel.set_state(state=temp_state,data=self.__data) 
    290             self.is_state_data = True             
     292                        
    291293 
    292294        except: 
  • invariantview/perspectives/invariant/invariant_panel.py

    r51fb7ab rd318616  
    8282        self.new_state = False 
    8383        self.is_power_out = False 
     84        self.is_state_data = False 
    8485 
    8586        #container of invariant value 
     
    117118        """ 
    118119        """ 
     120         
    119121        n = self.data_cbbox.GetCurrentSelection() 
    120         data, path = self.data_cbbox.GetClientData(n) 
    121         self._manager.compute_helper(data=data) 
    122         
     122        try: 
     123            data, path = self.data_cbbox.GetClientData(n) 
     124         
     125            if not self._data == data: 
     126                self._manager.compute_helper(data=data) 
     127            else: 
     128                msg = "The data named %s is already loaded..."% data.name 
     129                wx.PostEvent(self.parent, StatusEvent(status=msg)) 
     130        except: 
     131           self.data_cbbox.SetSelection(0) 
    123132     
    124133    def set_data(self, list=[], state=None): 
     
    128137        if not list: 
    129138            return  
     139        count_bf = self.data_cbbox.GetCount() 
    130140        for data, path in list: 
    131141            if data.__class__.__name__ != "Data2D" and \ 
    132142                data.name not in self.data_cbbox.GetItems(): 
    133                 self.data_cbbox.Insert(item=data.name, pos=0, 
     143                position = self.data_cbbox.GetCount() 
     144                self.data_cbbox.Insert(item=data.name, pos=position, 
    134145                                    clientData=(data, path)) 
    135         if self.data_cbbox.GetCount() >0: 
    136             self.data_cbbox.SetSelection(0) 
    137             self.data_cbbox.Enable() 
    138             self.on_select_data(event=None) 
     146        count = self.data_cbbox.GetCount() 
     147        if count >0: 
     148            # set data only on the first or state data  
     149            if count ==1 or self.is_state_data: 
     150                # when count increased especially if self.is_state_data. 
     151                if count > count_bf: 
     152                    self.data_cbbox.SetSelection(count-1) 
     153 
     154                self.data_cbbox.Enable() 
     155                self.on_select_data(event=None) 
     156                self.is_state_data = False 
     157             
    139158            title = "Untitled" 
    140159            if hasattr(data,"title"): 
     
    144163            else: 
    145164                title = str(data.name) 
    146  
     165     
    147166            wx.PostEvent(self.parent, NewPlotEvent(plot=data, title=title)) 
    148167             
Note: See TracChangeset for help on using the changeset viewer.