Mouse event - binding

B

beta

Hello All,

I am new with Python, your help would be very appreciated.

I have a simple pinpong applicaiton. I would like make a ball's color
change when mouse is clicked on it.

Here is my sample code:

from Tkinter import *

import string


class Pong(Frame):
def createWidgets(self):
self.QUIT = Button(self, text='QUIT', foreground='red',
command=self.quit)
self.QUIT.pack(side=LEFT, fill=BOTH)

## The playing field
self.draw = Canvas(self, width="5i", height="5i")

## The speed control for the ball
self.speed = Scale(self, orient=HORIZONTAL, label="ball speed",
from_=-100, to=100)

self.speed.pack(side=BOTTOM, fill=X)

# The ball
#self.ball = self.draw.create_oval("0i", "0i", "0.10i",
"0.10i",
# fill="red")
self.theBall()
self.x = 0.05
self.y = 0.05
self.velocity_x = 0.3
self.velocity_y = 0.5

self.draw.pack(side=LEFT)
def theBall(self):
self.ball = self.draw.create_oval("0i", "0i", "0.20i",
"0.20i",
fill="red")

def moveBall(self, *args):
if (self.x > 5.0) or (self.x < 0.0):
self.velocity_x = -1.0 * self.velocity_x
if (self.y > 5.0) or (self.y < 0.0):
self.velocity_y = -1.0 * self.velocity_y

deltax = (self.velocity_x * self.speed.get() / 100.0)
deltay = (self.velocity_y * self.speed.get() / 100.0)
self.x = self.x + deltax
self.y = self.y + deltay

self.draw.move(self.ball, "%ri" % deltax, "%ri" % deltay)
self.after(10, self.moveBall)

def __init__(self, master=None):
Frame.__init__(self, master)
Pack.config(self)
self.createWidgets()
self.after(10, self.moveBall)


game = Pong()

game.mainloop()

Thanks,
 
J

John McMonagle

Hello All,

I am new with Python, your help would be very appreciated.

I have a simple pinpong applicaiton. I would like make a ball's color
change when mouse is clicked on it.

Here is my sample code:

from Tkinter import *

import string


class Pong(Frame):
def createWidgets(self):
self.QUIT = Button(self, text='QUIT', foreground='red',
command=self.quit)
self.QUIT.pack(side=LEFT, fill=BOTH)

## The playing field
self.draw = Canvas(self, width="5i", height="5i")

## The speed control for the ball
self.speed = Scale(self, orient=HORIZONTAL, label="ball speed",
from_=-100, to=100)

self.speed.pack(side=BOTTOM, fill=X)

# The ball
#self.ball = self.draw.create_oval("0i", "0i", "0.10i",
"0.10i",
# fill="red")
self.theBall()
self.x = 0.05
self.y = 0.05
self.velocity_x = 0.3
self.velocity_y = 0.5

self.draw.pack(side=LEFT)
def theBall(self):
self.ball = self.draw.create_oval("0i", "0i", "0.20i",
"0.20i",
fill="red")

def moveBall(self, *args):
if (self.x > 5.0) or (self.x < 0.0):
self.velocity_x = -1.0 * self.velocity_x
if (self.y > 5.0) or (self.y < 0.0):
self.velocity_y = -1.0 * self.velocity_y

deltax = (self.velocity_x * self.speed.get() / 100.0)
deltay = (self.velocity_y * self.speed.get() / 100.0)
self.x = self.x + deltax
self.y = self.y + deltay

self.draw.move(self.ball, "%ri" % deltax, "%ri" % deltay)
self.after(10, self.moveBall)

def __init__(self, master=None):
Frame.__init__(self, master)
Pack.config(self)
self.createWidgets()
self.after(10, self.moveBall)


game = Pong()

game.mainloop()

Thanks,

--

You need to bind a button-1 event to the ball tag. After you initially
create the ball item:

self.draw.tag_bind(self.ball, '<Button-1>', changeColour)

where changeColour is a function like so:

def changeColour(self, event):
x = self.draw.canvasx(event.x)
y = self.draw.canvasy(event.y)
item = self.draw.find_closest(x,y)
currentColour = self.draw.itemcget(item, 'fill')
if currentColour == 'red':
self.draw.itemconfigure(item, fill='blue')
else:
self.draw.itemconfigure(item, fill='red')

This will toggle the ball colour between red and blue.

HTH,

John McMonagle
 
B

beta

Dear John,

Thanks for your help. I don't know how to bind the ball only into a
program. Would you mind help me on this? I added the changeColour
function, here is a complete program.

---------------------------
from Tkinter import *
import string

class Pong(Frame):
def createWidgets(self):
self.QUIT = Button(self, text='QUIT', foreground='red',
command=self.quit)
self.QUIT.pack(side=LEFT, fill=BOTH)

## The playing field
self.draw = Canvas(self, width="5i", height="5i")

## The speed control for the ball
self.speed = Scale(self, orient=HORIZONTAL, label="ball speed",
from_=-100, to=100)
self.speed.pack(side=BOTTOM, fill=X)

# The ball
self.ball = self.draw.create_oval("0i", "0i", "0.10i", "0.10i",
fill="red")
self.theBall()
self.x = 0.05
self.y = 0.05
self.velocity_x = 0.3
self.velocity_y = 0.5

self.draw.pack(side=LEFT)

def changeColour(self, event):
x = self.draw.canvasx(event.x)
y = self.draw.canvasy(event.y)
item = self.draw.find_closest(x,y)
currentColour = self.draw.itemcget(item, 'fill')
if currentColour == 'red':
self.draw.itemconfigure(item, fill='blue')
else:
self.draw.itemconfigure(item, fill='red')

def moveBall(self, *args):
if (self.x > 5.0) or (self.x < 0.0):
self.velocity_x = -1.0 * self.velocity_x
if (self.y > 5.0) or (self.y < 0.0):
self.velocity_y = -1.0 * self.velocity_y
deltax = (self.velocity_x * self.speed.get() / 100.0)
deltay = (self.velocity_y * self.speed.get() / 100.0)
self.x = self.x + deltax
self.y = self.y + deltay
self.draw.move(self.ball, "%ri" % deltax, "%ri" % deltay)
self.after(10, self.moveBall)

def __init__(self, master=None):
Frame.__init__(self, master)
Pack.config(self)
self.createWidgets()
self.after(10, self.moveBall)

game = Pong()
game.mainloop()

Thanks
 
J

John McMonagle

Dear John,

Thanks for your help. I don't know how to bind the ball only into a
program. Would you mind help me on this? I added the changeColour
function, here is a complete program.

....SNIP code...


Add the following code after you draw the ball item for the first time:

self.draw.tag_bind(self.ball, '<Button-1>', changeColour)
 
B

beta

Hi John,

It don't work!
I did what you told me, here is theBall function

def theBall(self):
self.ball = self.draw.create_oval("0i", "0i", "0.20i",
"0.20i",
fill="red")
self.draw.tag_bind(self.ball, '<Button-1>', changeColour)

Would you review all my code?

from Tkinter import *
import string

class Pong(Frame):
def createWidgets(self):
self.QUIT = Button(self, text='QUIT', foreground='red',
command=self.quit)
self.QUIT.pack(side=LEFT, fill=BOTH)

## The playing field
self.draw = Canvas(self, width="5i", height="5i")

## The speed control for the ball
self.speed = Scale(self, orient=HORIZONTAL, label="ball speed",
from_=-100, to=100)

self.speed.pack(side=BOTTOM, fill=X)

# The ball
#self.ball = self.draw.create_oval("0i", "0i", "0.10i",
"0.10i",
# fill="red")
self.theBall()
self.x = 0.05
self.y = 0.05
self.velocity_x = 0.3
self.velocity_y = 0.5

self.draw.pack(side=LEFT)
def theBall(self):
self.ball = self.draw.create_oval("0i", "0i", "0.20i",
"0.20i",
fill="red")
self.draw.tag_bind(self.ball, '<Button-1>', changeColour)

def changeColour(self, event):
x = self.draw.canvasx(event.x)
y = self.draw.canvasy(event.y)
item = self.draw.find_closest(x,y)
currentColour = self.draw.itemcget(item, 'fill')
if currentColour == 'red':
self.draw.itemconfigure(item, fill='blue')
else:
self.draw.itemconfigure(item, fill='red')

def moveBall(self, *args):
if (self.x > 5.0) or (self.x < 0.0):
self.velocity_x = -1.0 * self.velocity_x
if (self.y > 5.0) or (self.y < 0.0):
self.velocity_y = -1.0 * self.velocity_y

deltax = (self.velocity_x * self.speed.get() / 100.0)
deltay = (self.velocity_y * self.speed.get() / 100.0)
self.x = self.x + deltax
self.y = self.y + deltay

self.draw.move(self.ball, "%ri" % deltax, "%ri" % deltay)
self.after(10, self.moveBall)

def __init__(self, master=None):
Frame.__init__(self, master)
Pack.config(self)
self.createWidgets()
self.after(10, self.moveBall)
game = Pong()

game.mainloop()


Thanks,
Quoc
 
J

John McMonagle

Hi John,

It don't work!
I did what you told me, here is theBall function

def theBall(self):
self.ball = self.draw.create_oval("0i", "0i", "0.20i",
"0.20i",
fill="red")
self.draw.tag_bind(self.ball, '<Button-1>', changeColour)


Sorry, that should read:

self.draw.tag_bind(self.ball, '<Button-1>', self.changeColour)
 
J

John McMonagle

Hi John,

It don't work!
I did what you told me, here is theBall function

def theBall(self):
self.ball = self.draw.create_oval("0i", "0i", "0.20i",
"0.20i",
fill="red")
self.draw.tag_bind(self.ball, '<Button-1>', changeColour)

Sorry, that should read:

self.draw.tag_bind(self.ball, '<Button-1>', self.changeColour)
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

Forum statistics

Threads
473,769
Messages
2,569,580
Members
45,055
Latest member
SlimSparkKetoACVReview

Latest Threads

Top