本文整理汇总了Python中Tkinter.Scale.grid方法的典型用法代码示例。如果您正苦于以下问题:Python Scale.grid方法的具体用法?Python Scale.grid怎么用?Python Scale.grid使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Tkinter.Scale
的用法示例。
在下文中一共展示了Scale.grid方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: create_monitor
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
def create_monitor(self):
self.monitor_frame = LabelFrame(self, text="Monitor and Transport")
this_cycle = Scale(self.monitor_frame, label='cycle_pos', orient=HORIZONTAL,
from_=1, to=16, resolution=1)
this_cycle.disable, this_cycle.enable = (None, None)
this_cycle.ref = 'cycle_pos'
this_cycle.grid(column=0, row=0, sticky=E + W)
self.updateButton = Button(self.monitor_frame,
text='Reload all Settings',
command=self.request_update)
self.updateButton.grid(row=1, sticky=E + W)
self.ForceCaesuraButton = Button(self.monitor_frame,
text='Force Caesura',
command=self.force_caesura)
self.ForceCaesuraButton.grid(row=2, sticky=E + W)
self.saveBehaviourButton = Button(self.monitor_frame,
text='Save current behaviour',
command=self.request_saving_behaviour)
self.saveBehaviourButton.grid(row=3, sticky=E + W)
self.saveBehaviourNameEntry = Entry(self.monitor_frame)
self.saveBehaviourNameEntry.grid(row=4, sticky=E + W)
self.saveBehaviourNameEntry.bind('<KeyRelease>', self.request_saving_behaviour)
self.selected_behaviour = StringVar()
self.selected_behaviour.trace('w', self.new_behaviour_chosen)
self.savedBehavioursMenu = OptionMenu(self.monitor_frame,
self.selected_behaviour, None,)
self.savedBehavioursMenu.grid(row=5, sticky=E + W)
self.monitor_frame.grid(column=0, row=10, sticky=E + W)
示例2: JoystickFrame
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
class JoystickFrame(LabelFrame):
def __init__(self, master, tracker, text="Joystick", **options):
LabelFrame.__init__(self, master, text=text, **options)
self.tracker = tracker
self.width = 400
self.height = 400
self.canvas = Canvas(self, height=self.height, width=self.width)
self.canvas.grid()
self.canvas.create_oval((self.width/2 - 3, self.height/2 - 3,
self.width/2 + 3, self.height/2 + 3))
self.canvas.bind("<Button-1>",
bg_caller(lambda event: self.move_tracker(event)))
self.canvas.bind("<Motion>", self.update_label)
self.motion_label = Label(self, text="",
font=tkFont.Font(family="Courier"))
self.motion_label.grid()
f = LabelFrame(self, text="Sensitivity")
self.sensitivity_scale = Scale(f, from_=0, to=10,
resolution=0.01,
orient=HORIZONTAL,
length=self.width)
self.sensitivity_scale.set(5)
self.sensitivity_scale.grid()
f.grid()
@property
def sensitivity(self):
return self.sensitivity_scale.get() / 2000.
def get_delta(self, event):
dx = event.x - int(self.canvas['width'])/2.
dy = event.y - int(self.canvas['height'])/2.
dx_rad = dx*self.sensitivity
dy_rad = dy*self.sensitivity
dtheta = dy_rad
dphi = -dx_rad
return (dtheta, dphi)
def update_label(self, event):
dtheta, dphi = self.get_delta(event)
self.motion_label.configure(text="<{:8.5f}, {:8.5f}>".format(dtheta,
dphi))
def move_tracker(self, event):
dtheta, dphi = self.get_delta(event)
self.tracker.move(0, dtheta, dphi)
logger.info("Moved tracker by ({}, {})".format(dtheta, dphi))
示例3: SettingWindow
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
class SettingWindow(Toplevel):
def __init__(self, master, max_num_features, num_frames, mser_image):
Toplevel.__init__(self, master)
self.protocol('WM_DELETE_WINDOW', self.withdraw)
self.notebook = ttk.Notebook(self)
frame_feats = ttk.Frame(self.notebook)
frame_forest = ttk.Frame(self.notebook)
frame_mser = ttk.Frame(self.notebook)
frame_other = ttk.Frame(self.notebook)
self.notebook.add(frame_feats, text="Features ")
self.notebook.add(frame_forest, text=" Forest ")
self.notebook.add(frame_mser, text=" MSER ")
self.notebook.add(frame_other, text=" Other ")
self.max_num_feats = max_num_features
self.selection = None
self.mser_image = mser_image
rand_row = random.randint(1, 512-200)
rand_col = random.randint(1, 512-110)
self.mser_area = mser_image[rand_row:rand_row+180, rand_col:rand_col+100]
# read images from icons folder
self.hf0_img = PhotoImage(file="./icons/hf0.gif")
self.hf1_img = PhotoImage(file="./icons/hf1.gif")
self.hf2_img = PhotoImage(file="./icons/hf2.gif")
self.hf3_img = PhotoImage(file="./icons/hf3.gif")
self.hf4_img = PhotoImage(file="./icons/hf4.gif")
self.hf5_img = PhotoImage(file="./icons/hf5.gif")
self.features_vars = list()
for i in range(max_num_features):
self.features_vars.append(IntVar())
Label(frame_feats, text="Patch size (" + u"\N{GREEK SMALL LETTER PI}" + "):").grid(row=0, column=0, pady=5)
self.patch_size_spinbox = Spinbox(frame_feats, from_=3, to=30, width=3)
self.patch_size_spinbox.delete(0, END)
self.patch_size_spinbox.insert(END, 10)
self.patch_size_spinbox.grid(row=0, column=1, padx=5)
f1 = ttk.Labelframe(frame_feats, text='Mean filter')
f1.grid(row=1, columnspan=2)
Label(f1, text=u"\N{GREEK SMALL LETTER PI}").grid(row=0, column=0)
Checkbutton(f1, text="R", variable=self.features_vars[0]).grid(row=0, column=1)
Checkbutton(f1, text="G", variable=self.features_vars[1]).grid(row=0, column=2)
Checkbutton(f1, text="B", variable=self.features_vars[2]).grid(row=0, column=3)
Label(f1, text=u"\N{GREEK SMALL LETTER PI}" + "/2").grid(row=1, column=0)
Checkbutton(f1, text="R", variable=self.features_vars[3]).grid(row=1, column=1)
Checkbutton(f1, text="G", variable=self.features_vars[4]).grid(row=1, column=2)
Checkbutton(f1, text="B", variable=self.features_vars[5]).grid(row=1, column=3)
f2 = ttk.Labelframe(frame_feats, text="Gaussian filter")
f2.grid(row=2, columnspan=2)
Label(f2, text=str(1.0)).grid(row=0, column=0)
Checkbutton(f2, text="R", variable=self.features_vars[6]).grid(row=0, column=1)
Checkbutton(f2, text="G", variable=self.features_vars[7]).grid(row=0, column=2)
Checkbutton(f2, text="B", variable=self.features_vars[8]).grid(row=0, column=3)
Label(f2, text=str(3.5)).grid(row=1, column=0)
Checkbutton(f2, text="R", variable=self.features_vars[9]).grid(row=1, column=1)
Checkbutton(f2, text="G", variable=self.features_vars[10]).grid(row=1, column=2)
Checkbutton(f2, text="B", variable=self.features_vars[11]).grid(row=1, column=3)
f3 = ttk.Labelframe(frame_feats, text="Laplacian of gaussian")
f3.grid(row=3, columnspan=2)
Label(f3, text=str(2.0)).grid(row=0, column=0)
Checkbutton(f3, text="R", variable=self.features_vars[12]).grid(row=0, column=1)
Checkbutton(f3, text="G", variable=self.features_vars[13]).grid(row=0, column=2)
Checkbutton(f3, text="B", variable=self.features_vars[14]).grid(row=0, column=3)
Label(f3, text=str(3.5)).grid(row=1, column=0)
Checkbutton(f3, text="R", variable=self.features_vars[15]).grid(row=1, column=1)
Checkbutton(f3, text="G", variable=self.features_vars[16]).grid(row=1, column=2)
Checkbutton(f3, text="B", variable=self.features_vars[17]).grid(row=1, column=3)
f4 = ttk.Labelframe(frame_feats, text="Haar-like features")
f4.grid(row=1, rowspan=2, column=3, padx=5)
Checkbutton(f4, image=self.hf0_img, variable=self.features_vars[18]).grid(row=0, column=0)
Checkbutton(f4, image=self.hf1_img, variable=self.features_vars[19]).grid(row=0, column=1)
Checkbutton(f4, image=self.hf2_img, variable=self.features_vars[20]).grid(row=1, column=0)
Checkbutton(f4, image=self.hf3_img, variable=self.features_vars[21]).grid(row=1, column=1)
Checkbutton(f4, image=self.hf4_img, variable=self.features_vars[22]).grid(row=2, column=0)
Checkbutton(f4, image=self.hf5_img, variable=self.features_vars[23]).grid(row=2, column=1)
buttons_paned_window = PanedWindow(frame_feats, orient=VERTICAL)
buttons_paned_window.grid(row=3, column=3)
self.select_all_button = Button(buttons_paned_window, text="Select all", command=self._select_all)
buttons_paned_window.add(self.select_all_button)
self.clear_selection_button = Button(buttons_paned_window, text="Clear selection", command=self._clear_selection)
buttons_paned_window.add(self.clear_selection_button)
#.........这里部分代码省略.........
示例4: Logplayer
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
class Logplayer(Frame):
def __init__(self, root, logfn, viewer, analyzator=None, logdir=None, **kwargs):
self.root=root
self.logdir = logdir
self.analyzator = analyzator
if not self.logdir:
self.logdir=os.path.join(os.path.dirname(os.path.dirname(__file__)),'log')
Frame.__init__(self, **kwargs)
self.view=viewer(self, x=800, y=600, onLeft=self.clickL, onRight=self.clickR)
self.createWidgets()
self.bind_all("<Left>", self.prev)
self.bind_all("<Right>", self.next)
self.view.redraw()
self.root.update()
if not logfn:
logfn = self.logSelectDialog()
self.dirname, self.filename = os.path.split(logfn)
self.startRun(logfn,0)
self.view.redraw()
self.root.after(10,self.view.zoomExtens)
self.running=False
def logSelectDialog(self):
self.root.update()
timestamps, dirs, fns = zip(*sorted(listdir(self.logdir), reverse=True))
o=SelcectDialog(self.root, "select log", timestamps)
self.root.wait_window(o.top)
index=timestamps.index(o.option)
return os.path.join(dirs[index], fns[index])
def createWidgets(self):
self.controlFrame=Frame(self)
self.posScale = Scale(self.controlFrame, orient='horizontal',
length=210,
from_=0, tickinterval=0,
command=self.pos_callback,
showvalue=0,sliderlength=10, resolution=1)
#self.posScale.bind('<Button-1>',self.pos_start_drag)
#self.posScale.bind('<ButtonRelease-1>', self.pos_set)
self.playB=Button(self.controlFrame, text="play", command=self.playToggle)
self.nextB=Button(self.controlFrame, text="next", command=self.nextRun)
self.prevB=Button(self.controlFrame, text="prev", command=self.prevRun)
self.camera=tkimg(self, width=640, height=512)
self.controlFrame.grid(row=0,column=1, sticky="nw")
self.view.grid(row=1, column=1, sticky="nsew")
self.grid_columnconfigure(1,weight=1)
self.grid_rowconfigure(1,weight=1)
self.camera.grid(row = 1, column = 2, sticky = 'ne')
self.playB.grid(row=0, column=1)
self.prevB.grid(row=0, column=2)
self.nextB.grid(row=0, column=3)
self.posScale.grid(row=0, column=0)
def playToggle(self, *args):
if self.running:
self.root.after_cancel(self.cycleId)
else:
self.cycleId=self.root.after(20, self.showrun)
self.running=not self.running
def nextRun(self, *args):
self.changeRun(1)
def prevRun(self, *args):
self.changeRun(-1)
def changeRun(self, step):
if self.running:
self.root.after_cancel(self.cycleId)
self.running=False
run=self.loggenerator.run+step
if run >= len(self.loggenerator.runconfig) or run<0:
timestamps, dirs, fns = zip(*sorted(listdir(self.logdir)))
index=fns.index(self.filename)+step
if 0<=index<len(fns):
run = 0 if step==1 else -1
self.startRun(os.path.join(dirs[index], fns[index]), run)
else:
self.startRun(os.path.join(self.dirname, self.filename), run)
def restart(self, keeppostion=True, startposition=None):
self.loggenerator.startrun(self.loggenerator.run, startposition=startposition)
self.data=list(self.loggenerator)
if not keeppostion:
self.position=0
self.posScale.set(self.position)
self.showData(self.position)
def startRun(self, fn, run, keeppostion=False):
self.dirname, self.filename = os.path.split(fn)
print("starting log %s run %i"%(fn,run))
self.loggenerator=EduroMaxiReader(fn)
self.loggenerator.startrun(run)
self.root.title("%s %s run %i"%(self.dirname,self.filename, self.loggenerator.run+1))
#.........这里部分代码省略.........
示例5: Scraper
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
class Scraper():
def __init__(self, img_filename='snap.png'):
self.canvas = Canvas()
self.scales = []
self.canvas.pack()
self._current_image = None
self._original_image = None
self.root = self._load_gui()
self.open_image(img_filename)
self.repaint()
self.root.mainloop()
@property
def image(self):
return self._current_image
@image.setter
def image(self, value):
self._current_image = value
@property
def original_image(self):
return self._original_image
@image.setter
def image(self, value):
self._original_image = value
def open_image(self, filename):
self.original_image = Image.open(filename).copy()
self.image = self.original_image
def repaint(self):
rgb_min = (self.scale_red_min.get(), self.scale_green_min.get(), self.scale_blue_min.get())
rgb_max = (self.scale_red_max.get(), self.scale_green_max.get(), self.scale_blue_max.get())
print "repainting", rgb_min, rgb_max
self.image = strip_colors(self.original_image, rgb_min, rgb_max)
self._paint(self.image)
def _paint(self, image):
if image is not None:
# check if we need to resize the canvas, based on the size of the image being painted
image_width, image_height = image.size
if self.canvas.winfo_width() != image_width or self.canvas.winfo_height() != image_height:
self.canvas.config(width=image_width, height=image_height)
# paint the image to the canvas
self._img_tk = ImageTk.PhotoImage(image)
self.canvas.create_image(0, 0, image=self._img_tk, anchor=NW)
else:
print 'there is no image to paint'
return -1
def _load_gui(self):
root = Tk()
root.title("Scraper")
main_frame = Frame(root)
main_frame.grid(column=0, row=0, sticky=(N, W, E, S))
main_frame.columnconfigure(0, weight=1)
main_frame.rowconfigure(0, weight=1)
main_frame.pack()
self.scale_red_min = Scale(main_frame, from_=0, to=255, orient=HORIZONTAL, command=self._update_red_min)
self.scale_red_min.grid(column=1, row=1)
self.scale_red_max = Scale(main_frame, from_=0, to=255, orient=HORIZONTAL, command=self._update_red_max)
self.scale_red_max.grid(column=2, row=1)
self.scale_red_max.set(255)
self.scale_green_min = Scale(main_frame, from_=0, to=255, orient=HORIZONTAL, command=self._update_green_min)
self.scale_green_min.grid(column=1, row=2)
self.scale_green_max = Scale(main_frame, from_=0, to=255, orient=HORIZONTAL, command=self._update_green_max)
self.scale_green_max.grid(column=2, row=2)
self.scale_green_max.set(255)
self.scale_blue_min = Scale(main_frame, from_=0, to=255, orient=HORIZONTAL, command=self._update_blue_min)
self.scale_blue_min.grid(column=1, row=3)
self.scale_blue_max = Scale(main_frame, from_=0, to=255, orient=HORIZONTAL, command=self._update_blue_max)
self.scale_blue_max.grid(column=2, row=3)
self.scale_blue_max.set(255)
return root
def _update_red_min(self, value):
print 'updating red min to %s' % value
if self.scale_red_min.get() > self.scale_red_max.get():
self.scale_red_max.set(self.scale_red_min.get())
self.repaint()
def _update_red_max(self, value):
print 'updating red max to %s' % value
if self.scale_red_max.get() < self.scale_red_min.get():
self.scale_red_min.set(self.scale_red_max.get())
self.repaint()
def _update_green_min(self, value):
print 'updating green min to %s' % value
#.........这里部分代码省略.........
示例6: Application
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
class Application(Frame):
def __init__(self, master=None):
Frame.__init__(self, master)
self.sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
self.send_sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
self.sock.bind((host, port))
self.grid()
self.columnconfigure(0, minsize=100)
self.columnconfigure(1, minsize=200)
self.columnconfigure(2, minsize=200)
self.columnconfigure(3, minsize=150)
self.columnconfigure(4, minsize=150)
self.columnconfigure(5, minsize=150)
self.columnconfigure(6, minsize=150)
self.create_widgets()
self.settables = self.assemble_settables()
self.gui_logger = logging.getLogger('gui')
self.request_update()
def create_widgets(self):
self.create_monitor()
self.create_check_buttons()
self.create_ranges()
self.create_scales()
self.create_radio_buttons()
self.create_voices()
self.quitButton = Button(self, text='Quit', command=self.quit)
self.quitButton.grid(columnspan=7, sticky=E + W)
def assemble_settables(self):
settables = self.winfo_children()
for w in settables:
settables += w.winfo_children()
return filter(lambda w: w.__class__.__name__ in ['Scale', 'Checkbutton'], settables)
def create_radio_buttons(self):
# Scale related
entries = ['DIATONIC', 'HARMONIC', 'MELODIC', 'PENTATONIC', 'PENTA_MINOR']
self.scale = StringVar()
self.scale.set('DIATONIC')
self.rb_frame = Frame(self)
for e in entries:
rb = Radiobutton(self.rb_frame, value=e, text=e, anchor=W,
command=self.send_scale, variable=self.scale)
rb.grid(row=len(self.rb_frame.winfo_children()), sticky=W)
self.rb_frame.grid(column=1, row=len(self.grid_slaves(column=1)), rowspan=3)
def create_monitor(self):
self.monitor_frame = LabelFrame(self, text="Monitor and Transport")
this_cycle = Scale(self.monitor_frame, label='cycle_pos', orient=HORIZONTAL,
from_=1, to=16, resolution=1)
this_cycle.disable, this_cycle.enable = (None, None)
this_cycle.ref = 'cycle_pos'
this_cycle.grid(column=0, row=0, sticky=E + W)
self.updateButton = Button(self.monitor_frame,
text='Reload all Settings',
command=self.request_update)
self.updateButton.grid(row=1, sticky=E + W)
self.ForceCaesuraButton = Button(self.monitor_frame,
text='Force Caesura',
command=self.force_caesura)
self.ForceCaesuraButton.grid(row=2, sticky=E + W)
self.saveBehaviourButton = Button(self.monitor_frame,
text='Save current behaviour',
command=self.request_saving_behaviour)
self.saveBehaviourButton.grid(row=3, sticky=E + W)
self.saveBehaviourNameEntry = Entry(self.monitor_frame)
self.saveBehaviourNameEntry.grid(row=4, sticky=E + W)
self.saveBehaviourNameEntry.bind('<KeyRelease>', self.request_saving_behaviour)
self.selected_behaviour = StringVar()
self.selected_behaviour.trace('w', self.new_behaviour_chosen)
self.savedBehavioursMenu = OptionMenu(self.monitor_frame,
self.selected_behaviour, None,)
self.savedBehavioursMenu.grid(row=5, sticky=E + W)
self.monitor_frame.grid(column=0, row=10, sticky=E + W)
def request_update(self):
self.send({'sys': 'update'})
def request_saving_behaviour(self, event=None):
"""callback for save behaviour button and textentry"""
if event and event.widget == self.saveBehaviourNameEntry:
if event.keysym == 'Return':
name = self.saveBehaviourNameEntry.get()
self.saveBehaviourNameEntry.delete(0, len(name))
else:
return
else: # button was pressed
name = self.saveBehaviourNameEntry.get()
if name:
self.send({'sys': ['save_behaviour', name]})
def force_caesura(self):
self.send({'force_caesura': True})
def create_voices(self):
voice_ids = ['1', '2', '3', '4']
SCALES = OrderedDict([
('pan_pos', {'min': -1, 'max': 1, 'start': 0.5, 'res': 0.001}),
('volume', {'min': 0, 'max': 1, 'start': 0.666, 'res': 0.001}),
#.........这里部分代码省略.........
示例7: create_voices
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
def create_voices(self):
voice_ids = ['1', '2', '3', '4']
SCALES = OrderedDict([
('pan_pos', {'min': -1, 'max': 1, 'start': 0.5, 'res': 0.001}),
('volume', {'min': 0, 'max': 1, 'start': 0.666, 'res': 0.001}),
('slide_duration_msecs', {'min': 0, 'max': 2000, 'start': 60, 'res': 1}),
('slide_duration_prop', {'min': 0, 'max': 2, 'start': 0.666, 'res': 0.001}),
('binaural_diff', {'min': 0, 'max': 66, 'start': 0.2, 'res': 0.01})
])
for vid in voice_ids:
counter = 0
for sca in SCALES:
name = 'voice_' + vid + '_' + sca
setattr(self, 'min_' + name, SCALES[sca]['min'])
setattr(self, 'max_' + name, SCALES[sca]['max'])
this_sca = Scale(self, label=sca, orient=HORIZONTAL,
from_=getattr(self, 'min_' + name),
to=getattr(self, 'max_' + name),
resolution=SCALES[sca]['res'])
this_sca.enable = ('enable' in SCALES[sca].keys() and
SCALES[sca]['enable'] or None)
this_sca.disable = ('disable' in SCALES[sca].keys() and
SCALES[sca]['disable'] or None)
this_sca.grid(column=int(2 + int(vid)), row=counter, sticky=E + W)
this_sca.bind("<ButtonRelease>", self.scale_handler)
this_sca.ref = name
counter += 1
CHECK_BUTTONS = OrderedDict(
[('mute', False),
('automate_binaural_diffs', True),
('automate_note_duration_prop', True),
('use_proportional_slide_duration', {'val': True, 'label': 'proportional slide'}),
('automate_pan', True),
('automate_wavetables', True)])
for vid in voice_ids:
counter = 0
cb_frame = LabelFrame(self, text="Voice {0} - Automation".format(vid))
setattr(self, 'voice_' + vid + '_cb_frame', cb_frame)
for cb in CHECK_BUTTONS:
options = CHECK_BUTTONS[cb]
name = 'voice_' + vid + '_' + cb
label = (options['label'] if isinstance(options, dict) and
'label' in options.keys() else
(cb[9:] if cb[:9] == 'automate_' else cb))
setattr(self, name, IntVar(value=type(options) == dict and options['val'] or options))
self.this_cb = Checkbutton(cb_frame, text=label, variable=getattr(self, name))
self.this_cb.bind('<Button-1>', self.check_boxes_handler)
self.this_cb.disable = None
self.this_cb.grid(sticky=W, column=0, row=counter)
self.this_cb.ref = name
counter += 1
# add trigger wavetable-button
trigWavetableButton = Button(cb_frame, text='Next Wavetable')
trigWavetableButton.bind('<Button-1>', self.trigger_waveform_handler)
trigWavetableButton.ref = 'voice_' + vid + "_trigger_wavetable"
trigWavetableButton.grid(row=counter)
cb_frame.grid(column=int(vid) + 2, row=5, sticky=E + W + N, rowspan=8)
for vid in voice_ids:
generation_types = ["random", "random_harmonic", "harmonic"]
partial_pools = ["even", "odd", "all"]
prefix = 'voice_' + vid + '_'
types_name = prefix + 'wavetable_generation_type'
pools_name = prefix + 'partial_pool'
setattr(self, types_name, StringVar())
getattr(self, types_name).set("random")
setattr(self, pools_name, StringVar())
getattr(self, pools_name).set("all")
target_frame = getattr(self, 'voice_' + vid + '_cb_frame')
gen_typ_frame = LabelFrame(target_frame, text="type")
gen_typ_frame.grid(row=len(target_frame.winfo_children()), sticky=W)
for gen_t in generation_types:
gen_t_entry = Radiobutton(gen_typ_frame, value=gen_t, text=gen_t, anchor=W,
variable=getattr(self, types_name))
gen_t_entry.bind('<ButtonRelease-1>', self.wt_handler)
gen_t_entry.ref = types_name
gen_t_entry.grid(row=len(gen_typ_frame.winfo_children()), sticky=W)
pp_frame = LabelFrame(target_frame, text="harmonics")
for pp in partial_pools:
pp_entry = Radiobutton(pp_frame, value=pp, text=pp, anchor=W,
variable=getattr(self, pools_name))
pp_entry.bind('<ButtonRelease-1>', self.wt_handler)
pp_entry.ref = pools_name
pp_entry.grid(row=len(pp_frame.winfo_children()), sticky=E + W)
this_num_partials = Scale(pp_frame, label='number of harmonics', orient=HORIZONTAL,
from_=1, to=24, resolution=1)
this_num_partials.ref = prefix + 'num_partials'
this_num_partials.grid(column=0, row=len(pp_frame.winfo_children()), sticky=E + W)
this_num_partials.bind("<ButtonRelease>", self.scale_handler)
pp_frame.grid(row=len(target_frame.winfo_children()), sticky=E + W)
示例8: VRConfigDialog
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
class VRConfigDialog(Dialog):
"""
Defines a custom dialog for editing the Virtual Reality params
"""
def __init__(self, parent, populator=None, manager=None):
"""
Construct the dialog
"""
self._entries = {
"frame_angle" : None,
"distortion" : False,
"windowed" : False,
"eye_height" : None,
"minimum_dist_to_wall" : None
}
self._win_var = IntVar(0)
self._distortion_var = IntVar(0)
Dialog.__init__(self, parent=parent, title="VRConfiguration", populator=populator, manager=manager)
def body(self, parent):
"""
Overridden method defining the body of the dialog
:param parent:
:return:
"""
# Define all of the labels for our options
Label(parent, text="Frame Angle:", padx=3, anchor=SW, height=2).grid(row=0, column=0, sticky=W)
Label(parent, text="Eye Height:", padx=3, anchor=SW, height=2).grid(row=1, column=0, pady=2, sticky=W )
Label(parent, text="MinDistToWall:", padx=3, anchor=SW, height=2).grid(row=2, column=0, pady=2, sticky=W)
Label(parent, text="Distortion:", padx=3).grid(row=3, column=0, pady=2, sticky=W)
Label(parent, text="Windowed:", padx=3).grid(row=4, column=0, pady=2, sticky=W)
# Define the sub-widgets that the labels are referring to
self._frameAngle = Scale(parent, from_=-20, to=20, orient=HORIZONTAL)
if self._entries["frame_angle"] is not None:
self._frameAngle.set(self._entries["frame_angle"])
else:
self._frameAngle.set(-5)
self._frameAngle.grid(row=0, column=1, padx=3)
self._eyeHeight = Scale(parent, from_=0, to=500, orient=HORIZONTAL)
if self._entries["eye_height"] is not None:
self._eyeHeight.set( self._entries["eye_height"] )
else:
self._eyeHeight.set(50)
self._eyeHeight.grid(row=1, column=1, padx=3)
self._minDistToWall = Scale(parent, from_=1, to=300, orient=HORIZONTAL)
if self._entries["minimum_dist_to_wall"] is not None:
self._minDistToWall.set( self._entries["minimum_dist_to_wall"] )
else:
self._minDistToWall.set(20)
self._minDistToWall.grid(row=2, column=1, padx=3)
self._distortion = Checkbutton(parent, variable=self._distortion_var, offvalue=0, onvalue=1, text="Enable", command=self._toggle_distortion)
self._distortion.grid(row=3, column=1, padx=3)
self._windowed = Checkbutton(parent, variable=self._win_var, offvalue=0, onvalue=1, text="Enable", command=self._toggle_windowed)
self._windowed.grid(row=4, column=1, padx=3)
def _toggle_distortion(self):
"""
Toggle the distortion flag
:return:
"""
self._distortion_var.set(0 if self._distortion_var.get() == 1 else 1)
val = self._entries["distortion"]
self._entries["distortion"] = not val
Debug.printi("Distortion toggled to " + (str(not val)), Debug.Level.INFO)
self._distortion.toggle()
def _toggle_windowed(self):
"""
Toggle the windowed flag
:return:
"""
self._win_var.set(0 if self._win_var.get() == 1 else 1)
val = self._entries["windowed"]
self._entries["windowed"] = not val
Debug.printi("Windowing toggled to " + (str(not val)), Debug.Level.INFO)
self._windowed.toggle()
def populate(self, manager):
self._entries["frame_angle"] = manager.frame_angle
self._entries["distortion"] = manager.distortion
self._entries["windowed"] = manager.windowed
self._entries["eye_height"] = manager.eye_height
self._entries["minimum_dist_to_wall"] = manager.minimum_dist_to_wall
self._win_var.set( 0 if manager.windowed is False else 1 )
self._distortion_var.set( 0 if manager.distortion is False else 1 )
def validate(self):
(result, message) = DataValidator.validate(DataStore.EVENT.VR_EDIT, self._entries)
if result is not True:
tkMessageBox.showerror("Input Error", message)
return result
def apply(self):
#.........这里部分代码省略.........
示例9: SPIFrame
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
class SPIFrame(Frame):
def __init__(self, parent):
Frame.__init__(self, parent)
self.parent = parent
self.initialize()
def initialize(self):
self.grid()
self.entryVariable = StringVar()
self.entry = Entry(self, textvariable=self.entryVariable)
self.entry.grid(column=0,row=0,sticky='EW')
self.entry.bind("<Return>", self.OnPressEnter)
button = Button(self,text="SPI send", command=self.OnButtonClick)
button.grid(column=1,row=0)
#ramp = Button(self,text="RAMP", command=self.setlabvar)
#ramp.grid(column=1,row=1)
self.labelVariable = StringVar()
label = Label(self,textvariable=self.labelVariable,
anchor="w",fg="white",bg="blue")
label.grid(column=0,row=1,columnspan=1,sticky='EW')
self.labelVariable.set("Start..")
self.slider = Scale(self, from_=0, to=80, orient=HORIZONTAL,
command=self.setlabvar)
self.slider.grid(column=0, row=2, columnspan=3, sticky='EW')
self.PID = PIDTune(self)
self.PID.grid(column=0, row=3, columnspan=3, sticky='EW')
self.grid_columnconfigure(0,weight=1)
self.update()
#self.geometry(self.geometry()) # caused busy wait?
self.entry.focus_set()
#self.entry.selection_range(0, Tkinter.END) # caused busy wait?
def setlabvar(self, val):
val = self.slider.get()
speed.SetAcceleration(val)
accel = val;
self.labelVariable.set("Duty set: " + str(val) )
def OnButtonClick(self):
accel = int(self.entryVariable.get())
self.slider.set(accel)
speed.SetAcceleration(accel)
self.labelVariable.set("Duty set: " + str(accel) )
self.entry.focus_set()
self.entry.selection_range(0, END)
def OnPressEnter(self,event):
accel = int(self.entryVariable.get())
self.slider.set(accel)
speed.SetAcceleration(accel)
self.labelVariable.set("Duty set: " + str(accel) )
self.entry.focus_set()
self.entry.selection_range(0, END)
示例10: gui
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
def gui():
from Tkinter import Tk, Label, Entry,Button, Scale, Checkbutton,W,HORIZONTAL, Frame, StringVar, IntVar, DoubleVar, Radiobutton, BooleanVar, E
global root
root = Tk()
root.wm_title("Compute R_complete")
line = 0
global insFile, hklFile, nHKL, nParams, nHKLLabel, fracFree, status, nParamsLabel, nCPU, rCompleteLabel, cycles, lsType, cleanup,nFree, nRunsLabel, mergeCheck, compileMap
insFile = StringVar()
hklFile = StringVar()
nHKL = IntVar()
nParams = IntVar()
nFree = IntVar()
fracFree = DoubleVar()
fracFree.set(5.0)
nCPU = IntVar()
nCPU.set(maxCPU)
cycles = IntVar()
cycles.set(10)
lsType = IntVar()
lsType.set(1)
cleanup = BooleanVar()
cleanup.set(True)
mergeCheck = BooleanVar()
mergeCheck.set(True)
compileMap = BooleanVar()
compileMap.set(True)
Label(root, text='Instruction File:').grid(row=line, column=0, sticky=E)
Entry(root, textvariable=insFile).grid(row=line, column=1)
Button(root, text='Browse', command=browseINS).grid(row=line, column=2)
line += 1
Label(root, text='Reflection File:').grid(row=line, column=0, sticky=E)
Entry(root, textvariable=hklFile).grid(row=line, column=1)
Button(root, text='Browse', command=browseHKL).grid(row=line, column=2)
line += 1
Checkbutton(root, var=mergeCheck, text='Merge Reflections').grid(row=line, column=1, sticky=W)
line += 1
Button(root, text='Load', command=load).grid(row=line, columnspan=3)
line += 1
Frame(root, height=20).grid(row=line)
line += 1
Label(root, text='# of reflections:').grid(row=line, sticky=E)
nHKLLabel = Label(root, text='???')
nHKLLabel.grid(row=line, column=1, sticky=W)
line += 1
Label(root, text='# of atoms:').grid(row=line, sticky=E)
nParamsLabel = Label(root, text='???')
nParamsLabel.grid(row=line, column=1, sticky=W)
line += 1
Frame(root, height=20).grid(row=line)
line += 1
Label(root, text='Select Parameters').grid(row=line, column=1)
line += 1
Frame(root, height=20).grid(row=line)
line += 1
Label(root, text='# of free reflections:').grid(row=line, sticky=E)
nFreeEntry = Entry(root, width=5, textvariable=nFree)
nFreeEntry.grid(row=line, column=1, sticky=W)
nFreeEntry.bind('<Return>', setScale)
nRunsLabel = Label(root, text='# runs')
nRunsLabel.grid(row=line, column=2)
line += 1
Label(root, text='% of free reflections:').grid(row=line, column=0, sticky=E)
w = Scale(root, from_=0.1, to=10.0, resolution=0.1, orient=HORIZONTAL, length=200, var=fracFree, command=percentScale)
w.grid(row=line, column=1, columnspan=2, sticky=W)
line += 1
Label(root, text='stable <-------------------------------> fast').grid(row=line, column=1, columnspan=2, sticky=W)
line += 1
Frame(root, height=10).grid(row=line)
line += 1
Label(root, text='Refinement cycles:').grid(row=line, column=0, sticky=E)
ls = Scale(root, from_=0, to=50, resolution=1, orient=HORIZONTAL, length=200, var=cycles)
ls.grid(row=line, column=1, columnspan=2, sticky=W)
#.........这里部分代码省略.........
示例11: OfflineVisualiser
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
class OfflineVisualiser(Visualiser):
"""A VTK-powered offline visualiser which runs in its own thread.
In addition to the functions provided by the standard visualiser,
the following additional functions are provided:
precache_height_quantities() - Precache all the vtkpoints
structures for any dynamic height based quantities to render.
"""
def __init__(self, source, frameDelay=100, frameStep=1):
"""The source parameter is assumed to be a NetCDF sww file.
The frameDelay parameter is the number of milliseconds waited between frames.
"""
Visualiser.__init__(self, source)
self.frameNumber = 0
fin = NetCDFFile(self.source, 'r')
self.maxFrameNumber = fin.variables['time'].shape[0] - 1
fin.close()
#self.frameNumberTkVariable = StringVar()
#self.frameNumberTkVariable.set('Frame - %05g'%self.framNumber)
self.frameDelay = frameDelay
self.xmin = None
self.xmax = None
self.ymin = None
self.ymax = None
self.zmin = None
self.zmax = None
self.frameStep= frameStep
self.vtk_heightQuantityCache = []
for i in range(self.maxFrameNumber + 1): # maxFrameNumber is zero indexed.
self.vtk_heightQuantityCache.append({})
self.paused = False
self.movie = False
def setup_grid(self):
fin = NetCDFFile(self.source, 'r')
self.vtk_cells = vtkCellArray()
N_tri = fin.variables['volumes'].shape[0]
for v in range(N_tri):
self.vtk_cells.InsertNextCell(3)
for i in range(3):
self.vtk_cells.InsertCellPoint(fin.variables['volumes'][v][i])
fin.close()
def update_height_quantity(self, quantityName, dynamic=True):
polydata = self.vtk_polyData[quantityName] = vtkPolyData()
if dynamic is True:
#print ' - Frame',self.frameNumber,'of',self.maxFrameNumber
if not self.vtk_heightQuantityCache[self.frameNumber].has_key(quantityName):
self.vtk_heightQuantityCache[self.frameNumber][quantityName]\
= self.read_height_quantity(quantityName, True, self.frameNumber);
polydata.SetPoints(self.vtk_heightQuantityCache[self.frameNumber][quantityName])
else:
polydata.SetPoints(self.read_height_quantity(quantityName, False))
polydata.SetPolys(self.vtk_cells)
def get_3d_bounds(self):
return [self.xmin, self.xmax, self.ymin, self.ymax, self.zmin, self.zmax]
def read_height_quantity(self, quantityName, dynamic=True, frameNumber=0):
"""Read in a height based quantity from the NetCDF source file
and return a vtkPoints object. frameNumber is ignored if
dynamic is false."""
fin = NetCDFFile(self.source, 'r')
points = vtkPoints()
if dynamic is True:
N_vert = fin.variables[quantityName].shape[1]
else:
N_vert = len(fin.variables[quantityName])
x = num.ravel(num.array(fin.variables['x'], num.float))
y = num.ravel(num.array(fin.variables['y'], num.float))
if dynamic is True:
q = num.array(fin.variables[quantityName][frameNumber], num.float)
else:
q = num.ravel(num.array(fin.variables[quantityName], num.float))
q *= self.height_zScales[quantityName]
q += self.height_offset[quantityName]
for v in range(N_vert):
points.InsertNextPoint(x[v], y[v], q[v])
if self.xmin == None or self.xmin > x[v]:
self.xmin = x[v]
if self.xmax == None or self.xmax < x[v]:
self.xmax = x[v]
if self.ymin == None or self.ymin > y[v]:
self.ymin = y[v]
if self.ymax == None or self.ymax < y[v]:
self.ymax = y[v]
if self.zmin == None or self.zmin > q[v]:
self.zmin = q[v]
if self.zmax == None or self.zmax < q[v]:
self.zmax = q[v]
fin.close()
#.........这里部分代码省略.........
示例12: Cockpit
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
#.........这里部分代码省略.........
else:
self._link = ConsoleLink()
self._link.open()
self._updateInfoThread = Thread(target=self._updateInfo)
self._updateInfoThreadRunning = False
self._readingState = False
self._start()
def initUI(self):
self.parent.title("Drone control")
self.style = Style()
self.style.theme_use("default")
self.pack(fill=BOTH, expand=1)
self.parent.bind_all("<Key>", self._keyDown)
self.parent.bind_all("<KeyRelease>", self._keyUp)
if system() == "Linux":
self.parent.bind_all("<Button-4>", self._onMouseWheelUp)
self.parent.bind_all("<Button-5>", self._onMouseWheelDown)
else:
#case of Windows
self.parent.bind_all("<MouseWheel>", self._onMouseWheel)
#Commands
commandsFrame = tkFrame(self)
commandsFrame.grid(column=0, row=0, sticky="WE")
self._started = IntVar()
self._startedCB = Checkbutton(commandsFrame, text="On", variable=self._started, command=self._startedCBChanged)
self._startedCB.pack(side=LEFT, padx=4)
# self._integralsCB = Checkbutton(commandsFrame, text="Int.", variable=self._integralsEnabled, \
# command=self._integralsCBChanged, state=DISABLED)
# self._integralsCB.pack(side=LEFT, padx=4)
self._quitButton = Button(commandsFrame, text="Quit", command=self.exit)
self._quitButton.pack(side=LEFT, padx=2, pady=2)
# self._angleLbl = Label(commandsFrame, text="Angle")
# self._angleLbl.pack(side=LEFT, padx=4)
#
# self._angleEntry = Entry(commandsFrame, state=DISABLED)
# self._angleEntry.pack(side=LEFT)
#Info
infoFrame = tkFrame(self)
infoFrame.grid(column=1, row=1, sticky="NE", padx=4)
#Throttle
Label(infoFrame, text="Throttle").grid(column=0, row=0, sticky="WE")
self._throttleTexts = [StringVar(),StringVar(),StringVar(),StringVar()]
Entry(infoFrame, textvariable=self._throttleTexts[3], state=DISABLED, width=5).grid(column=0, row=1)
Entry(infoFrame, textvariable=self._throttleTexts[0], state=DISABLED, width=5).grid(column=1, row=1)
Entry(infoFrame, textvariable=self._throttleTexts[2], state=DISABLED, width=5).grid(column=0, row=2)
Entry(infoFrame, textvariable=self._throttleTexts[1], state=DISABLED, width=5).grid(column=1, row=2)
#Angles
Label(infoFrame, text="Angles").grid(column=0, row=3, sticky="WE")
示例13: Cockpit
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
#.........这里部分代码省略.........
else:
self._link = ConsoleLink()
self._link.open()
self._updateInfoThread = Thread(target=self._updateInfo)
self._updateInfoThreadRunning = False
self._readingState = False
self._start()
def initUI(self):
self.parent.title("Drone control")
self.style = Style()
self.style.theme_use("default")
self.pack(fill=BOTH, expand=1)
self.parent.bind_all("<Key>", self._keyDown)
self.parent.bind_all("<KeyRelease>", self._keyUp)
if system() == "Linux":
self.parent.bind_all("<Button-4>", self._onMouseWheelUp)
self.parent.bind_all("<Button-5>", self._onMouseWheelDown)
else:
#case of Windows
self.parent.bind_all("<MouseWheel>", self._onMouseWheel)
#Commands
commandsFrame = tkFrame(self)
commandsFrame.grid(column=0, row=0, sticky="WE")
self._startedCB = Checkbutton(commandsFrame, text="On", variable=self._started, command=self._startedCBChanged)
self._startedCB.pack(side=LEFT, padx=4)
self._integralsCB = Checkbutton(commandsFrame, text="Int.", variable=self._integralsEnabled, \
command=self._integralsCBChanged, state=DISABLED)
self._integralsCB.pack(side=LEFT, padx=4)
self._quitButton = Button(commandsFrame, text="Quit", command=self.exit)
self._quitButton.pack(side=LEFT, padx=2, pady=2)
# self._angleLbl = Label(commandsFrame, text="Angle")
# self._angleLbl.pack(side=LEFT, padx=4)
#
# self._angleEntry = Entry(commandsFrame, state=DISABLED)
# self._angleEntry.pack(side=LEFT)
#Info
infoFrame = tkFrame(self)
infoFrame.grid(column=1, row=1, sticky="E", padx=4)
#Throttle
Label(infoFrame, text="Throttle").grid(column=0, row=0, sticky="WE")
self._throttleTexts = [StringVar(),StringVar(),StringVar(),StringVar()]
Entry(infoFrame, textvariable=self._throttleTexts[3], state=DISABLED, width=5).grid(column=0, row=1)
Entry(infoFrame, textvariable=self._throttleTexts[0], state=DISABLED, width=5).grid(column=1, row=1)
Entry(infoFrame, textvariable=self._throttleTexts[2], state=DISABLED, width=5).grid(column=0, row=2)
Entry(infoFrame, textvariable=self._throttleTexts[1], state=DISABLED, width=5).grid(column=1, row=2)
#Angles
Label(infoFrame, text="Angles").grid(column=0, row=3, sticky="WE")
self._angleTexts = [StringVar(),StringVar(),StringVar()]
示例14: EnviroDialog
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
class EnviroDialog(Dialog):
"""
Dialog for editing the simulation environment details
"""
def __init__(self, parent, populator=None, manager=None):
"""
Construct the dialog
:param parent: The tk element that is the parent of the dialog
:return: An instance of EnviroDialog
"""
self._entries = {
"floor_texture": None,
"wall_height": None,
"edge_width": None,
"sky_texture": None,
"start_node": None
}
Dialog.__init__(self, parent=parent, title="EnvironmentConfiguration", populator=populator, manager=manager)
def body(self, parent):
"""
Overridden method defining the body of the dialog
:param parent:
:return:
"""
self._floorSel = ImagePicker(parent, "Floor Texture:",
default=self._entries["floor_texture"], auto_move=True, move_fold="Data")
self._floorSel.grid(row=0, columnspan=4)
self._skySel = ImagePicker(parent, "Sky Texture:", default=self._entries["sky_texture"], auto_move=True, move_fold="Data")
self._skySel.grid(row=1, columnspan=4)
Label(parent, text="Wall Height:", width=10, anchor=W).grid(row=2, column=0, sticky=W)
Label(parent, text="Edge Width:", width=10, anchor=W).grid(row=3, column=0, sticky=W)
self._wallScale = Scale(parent, from_=10, to=1000, orient=HORIZONTAL)
if self._entries["wall_height"] is not None:
self._wallScale.set(self._entries["wall_height"])
self._wallScale.grid(row=2, column=1, columnspan=2, sticky=W)
self._edgeScale = Scale(parent, from_=10, to=1000, orient=HORIZONTAL)
if self._entries["edge_width"] is not None:
self._edgeScale.set(self._entries["edge_width"])
self._edgeScale.grid(row=3, column=1, columnspan=2, sticky=W)
Label(parent, text="Starting Node:", anchor=W).grid(row=4, column=0, sticky=W)
self._start_node = Label(parent, text=self._entries["start_node"], anchor=W)
self._start_node.grid(row=4, column=1, sticky=W)
def populate(self, manager):
self._entries["floor_texture"] = manager.floor_texture
self._entries["edge_width"] = manager.edge_width
self._entries["sky_texture"] = manager.sky_texture
self._entries["start_node"] = manager.start_node
self._entries["edge_width"] = manager.edge_width
self._entries["wall_height"] = manager.wall_height
def validate(self):
(result, message) = DataValidator.validate(DataStore.EVENT.ENVIRONMENT_EDIT, {
"floor_texture" : self._floorSel.get(),
"sky_texture" : self._skySel.get()
})
if result is not True:
tkMessageBox.showerror("Input Error", message)
return result
def apply(self):
self._entries["floor_texture"] = self._floorSel.get()
self._entries["edge_width"] = self._edgeScale.get()
self._entries["sky_texture"] = self._skySel.get()
self._entries["wall_height"] = self._wallScale.get()
self._manager.inform(DataStore.EVENT.ENVIRONMENT_EDIT, self._entries)
def auto_populate(self):
self._floorSel.set(Defaults.Environment.FLOOR_TEXTURE)
self._skySel.set(Defaults.Environment.SKY_TEXTURE)
self._wallScale.set(Defaults.Environment.WALL_HEIGHT)
self._edgeScale.set(Defaults.Environment.EDGE_WIDTH)
self._start_node.config(text=Defaults.Environment.START_NODE)
示例15: ObjectDialog
# 需要导入模块: from Tkinter import Scale [as 别名]
# 或者: from Tkinter.Scale import grid [as 别名]
class ObjectDialog(Dialog):
"""
A custom dialog that allows the user to configure placing objects in the virtual environment
"""
def __init__(self, parent, x=None, y=None, populator=None):
"""
Construct the instance of the object dialog
:param parent: The parent tk instance that spawns the dialog
"""
self._entries = {
"x_coordinate" : None,
"y_coordinate" : None,
"name" : None,
"mesh" : None,
"scale" : None
}
self._scale_text = StringVar()
self._scale_text.set(str(1))
Dialog.__init__(self, parent, "ObjectBuilder", True, x, y, populator)
def body(self, parent):
"""
Define the custom body of the dialog
:param parent: The parent instance of the dialog
"""
# Define the labels of all of the sub widgets that are to be used
Label(parent, text="Name:").grid(row=0, column=0, sticky=W)
Label(parent, text="X-Coord:").grid(row=1, column=0, sticky=W)
Label(parent, text="Y-Coord:").grid(row=1, column=2, sticky=W)
Label(parent, text="Mesh:").grid(row=2, column=0, sticky=W)
Label(parent, text="Scale:").grid(row=3, column=0, sticky=W)
Label(parent, textvariable=self._scale_text, bg="grey").grid(row=3, column=1, sticky=W)
#Define the text entry widgets
self._object_name = Label(parent, text=self._entries["name"])
self._object_name.grid(column=1, row=0, sticky=W)
self._x_coord = Label(parent, text=self._entries["x_coordinate"])
self._x_coord.grid(column=1, row=1, sticky=W)
self._y_coord = Label(parent, text=self._entries["y_coordinate"])
self._y_coord.grid(column=3, row=1, stick=W)
self._mesh = Entry(parent, width=15, text=self._entries["mesh"])
if self._entries["mesh"] is None:
self._mesh.insert(0, "No mesh loaded")
else:
self._mesh.insert(0, self._entries["mesh"])
self._mesh.grid(column=1, row=2, columnspan=2, sticky=W)
Button(parent, text="Load", width=5, command=self._load_mesh, default=ACTIVE).grid(column=3, row=2)
self._scale = Scale(parent, from_=1, to=100, orient=HORIZONTAL, length=140, variable=self._scale_text, showvalue=0)
if self._entries["scale"] is not None:
self._scale.set(self._entries["scale"])
self._scale_text.set(str(self._entries["scale"]))
self._scale.grid(row=3, column=2, columnspan=2, sticky=W)
def validate(self):
(result, message) = DataValidator.validate(DataStore.EVENT.OBJECT_EDIT,
{
"name" : self._entries["name"],
"mesh" : self._mesh.get()
})
if result is not True:
tkMessageBox.showerror("Input Error", message)
return result
def apply(self):
self._entries["scale"] = self._scale.get()
self._entries["mesh"] = self._mesh.get()
def _load_mesh(self):
"""
Open a file dialog to load a mesh filepath
:return:
"""
Debug.printi("Load Mesh called", Debug.Level.INFO)
types = \
[
("DirectX", "*.x")
]
dialog = tkFileDialog.Open(self, filetypes=types)
file_path = dialog.show()
file_path = self._move_img(file_path)
self._mesh.delete(0, END)
self._mesh.insert(0, str(file_path))
Debug.printi("Mesh Filepath:" + file_path, Debug.Level.INFO)
def _move_img(self, file_path):
"""
Move the DirectX file to the Data folder automagically
:param file_path: The file path of the file to be moved
:return:
"""
try:
src = file_path
file_name = self._scrub_name(file_path)
dest = os.path.dirname(os.path.realpath(__file__)) + "/" + file_name
shutil.copy(src, dest)
#.........这里部分代码省略.........