Commit 69c639e6 authored by Duane Johnson's avatar Duane Johnson

Functioning xy control

parent 65350244
import wx, os, math
from bufferedcanvas import *
def imagefile(filename):
return os.path.join(os.path.dirname(__file__), "images", filename)
class XYButtons(wx.StaticBitmap):
class XYButtons(BufferedCanvas):
keypad_positions = {
0: (102, 109),
1: (78, 86),
2: (49, 58)
}
concentric_circle_radii = [19, 44, 80, 125]
center = (145, 147)
concentric_circle_radii = [19, 45, 81, 120]
center = (146, 149)
distance = [
# Order of Magnitude 0 (i.e. 0.1, 1, 10)
[
......@@ -37,26 +37,22 @@ class XYButtons(wx.StaticBitmap):
]
]
def __init__(self, parent):
def __init__(self, parent, ID=-1):
self.bg_bmp = wx.Image(imagefile("control_xy.png"),wx.BITMAP_TYPE_PNG).ConvertToBitmap()
self.keypad_bmp = wx.Image(imagefile("arrow_keys.png"),wx.BITMAP_TYPE_PNG).ConvertToBitmap()
self.keypad_idx = 0
self.orderOfMagnitude = 0
self.quadrant = None
self.concentric = None
# Set up background image
bmp = wx.Image(imagefile("control_xy.png"),wx.BITMAP_TYPE_PNG).ConvertToBitmap()
self.bg_bmp = wx.StaticBitmap.__init__(self, parent, -1, bmp, (0, 0))
bmp = wx.Image(imagefile("arrow_keys.png"),wx.BITMAP_TYPE_PNG).ConvertToBitmap()
self.keypad_bmp = wx.StaticBitmap(self, -1, bmp, XYButtons.keypad_positions[self.keypad_idx])
BufferedCanvas.__init__(self, parent, ID)
# Set up mouse and keyboard event capture
self.Bind(wx.EVT_LEFT_DOWN, self.OnLeftDown)
self.Bind(wx.EVT_LEFT_DCLICK, self.OnLeftDown)
self.Bind(wx.EVT_MOTION, self.OnMotion)
parent.Bind(wx.EVT_CHAR_HOOK, self.onKey)
# Paint
self.Bind(wx.EVT_PAINT, self.OnPaint)
def onKey(self, evt):
if evt.GetKeyCode() == wx.WXK_TAB:
self.setKeypadIndex(self.rotateKeypadIndex())
......@@ -86,7 +82,8 @@ class XYButtons(wx.StaticBitmap):
def setKeypadIndex(self, idx):
self.keypad_idx = idx
self.keypad_bmp.Move(XYButtons.keypad_positions[self.keypad_idx])
self.update()
# self.keypad_bmp.Move(XYButtons.keypad_positions[self.keypad_idx])
def getQuadrantConcentricFromPosition(self, pos):
rel_x = pos[0] - XYButtons.center[0]
......@@ -104,32 +101,111 @@ class XYButtons(wx.StaticBitmap):
idx = self.lookupConcentric(radius)
return (quadrant, idx)
def mouseOverKeypad(self, mpos):
for idx, kpos in XYButtons.keypad_positions.items():
rect = wx.Rect(kpos[0], kpos[1], 44, 32)
if rect.Contains(mpos):
return idx
return None
def OnMotion(self, event):
oldq, oldc = self.quadrant, self.concentric
mpos = event.GetPosition()
quadrant, concentric = self.getQuadrantConcentricFromPosition(mpos)
idx = self.mouseOverKeypad(mpos)
if idx != None:
self.quadrant = None
self.concentric = None
else:
self.quadrant, self.concentric = self.getQuadrantConcentricFromPosition(mpos)
# print 'motion:', mpos, quadrant, concentric
if oldq != self.quadrant or oldc != self.concentric:
self.update()
def OnLeftDown(self, event):
mpos = event.GetPosition()
for idx, kpos in XYButtons.keypad_positions.items():
rect = wx.Rect(kpos[0], kpos[1], 44, 32)
if rect.Contains(mpos):
idx = self.mouseOverKeypad(mpos)
if idx != None:
self.setKeypadIndex(idx)
quadrant, concentric = self.getQuadrantConcentricFromPosition(mpos)
print 'click:', mpos, quadrant, concentric
def OnPaint(self, event):
# wx.StaticBitmap.OnPaint(self, event)
dc = wx.PaintDC(self)
# dc.Clear()
# print 'click:', mpos, quadrant, concentric
if concentric == -1:
print 'center button'
elif quadrant != None and concentric != None:
dist = XYButtons.distance[self.orderOfMagnitude][quadrant][concentric]
print 'x', dist[0], 'y', dist[1]
def drawPartialPie(self, dc, center, r1, r2, angle1, angle2):
parts = 64
angle_dist = angle2 - angle1
angle_inc = angle_dist / parts
p1 = wx.Point(center.x + r1*math.cos(angle1), center.y + r1*math.sin(angle1))
p2 = wx.Point(center.x + r2*math.cos(angle1), center.y + r2*math.sin(angle1))
p3 = wx.Point(center.x + r2*math.cos(angle2), center.y + r2*math.sin(angle2))
p4 = wx.Point(center.x + r1*math.cos(angle2), center.y + r1*math.sin(angle2))
points = [p1, p2]
points.extend([wx.Point(
center.x + r1*math.cos(angle1+i*angle_inc),
center.y + r1*math.sin(angle1+i*angle_inc)) for i in range(0, parts)])
# points.extend([p3])
points.extend([wx.Point(
center.x + r2*math.cos(angle1+i*angle_inc),
center.y + r2*math.sin(angle1+i*angle_inc)) for i in range(parts, 0, -1)])
dc.DrawPolygon(points)
def highlightQuadrant(self, dc, quadrant, concentric):
assert(quadrant >= 0 and quadrant <= 3)
assert(concentric >= 0 and concentric <= 2)
inner_ring_radius = XYButtons.concentric_circle_radii[0]
# fudge = math.pi*0.002
fudge = 0
center = wx.Point(XYButtons.center[0], XYButtons.center[1])
if quadrant == 0:
a1, a2 = (-math.pi*0.25, math.pi*0.25)
center.x += inner_ring_radius
elif quadrant == 1:
a1, a2 = (math.pi*1.25, math.pi*1.75)
center.y -= inner_ring_radius
elif quadrant == 2:
a1, a2 = (math.pi*0.75, math.pi*1.25)
center.x -= inner_ring_radius
elif quadrant == 3:
a1, a2 = (math.pi*0.25, math.pi*0.75)
center.y += inner_ring_radius
r1 = XYButtons.concentric_circle_radii[concentric]
r2 = XYButtons.concentric_circle_radii[concentric+1]
self.drawPartialPie(dc, center, r1-inner_ring_radius, r2-inner_ring_radius, a1+fudge, a2-fudge)
def draw(self, dc):
# print 'draw called'
dc.Clear()
center = wx.Point(XYButtons.center[0], XYButtons.center[1])
start = wx.Point(50, 0)
end = wx.Point(0, 50)
dc.SetPen(wx.Pen(wx.Colour(0,0,0), 4))
dc.SetBrush(wx.Brush(wx.Colour(255,0,0)))
dc.DrawArcPoint(start, end, center)
dc.SetPen(wx.Pen(wx.Colour(100,100,100,172), 4))
dc.SetBrush(wx.Brush(wx.Colour(0,0,0,128)))
dc.DrawBitmap(self.bg_bmp, 0, 0)
# dc.DrawArc(50, 0, 0, 50, XYButtons.center[0], XYButtons.center[1])
# self.drawPartialPie(dc, center, 19, 44, -math.pi/4, math.pi/4)
if self.concentric == -1:
pass
elif self.quadrant != None and self.concentric != None:
self.highlightQuadrant(dc, self.quadrant, self.concentric)
pos = XYButtons.keypad_positions[self.keypad_idx]
dc.DrawBitmap(self.keypad_bmp, pos[0], pos[1])
# dc.DrawArcPoint(start, end, center)
return True
......@@ -146,19 +222,5 @@ class MyApp(wx.App):
frame.Centre()
return True
# def main():
# app = wx.App()
# frame = wx.Frame(None, title='Icon', pos=(350,300))
# # frame.SetIcon(wx.Icon('tipi.ico', wx.BITMAP_TYPE_ICO))
# frame.Center()
# frame.Show()
# panel = wx.Panel(self, -1)
# button = wx.Button(panel, -1, "Button1", (0,0))
# # wx.Image('stock_exit-16.png',wx.BITMAP_TYPE_PNG).ConvertToBitmap()
# app.MainLoop()
app = MyApp(0)
app.MainLoop()
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment