Activities/Turtle Art/Programmable Brick: Difference between revisions
m moved Activities/TurtleArt/Programmable Brick to Activities/Turtle Art/Programmable Brick: deCamelCase |
|||
(21 intermediate revisions by 2 users not shown) | |||
Line 38: | Line 38: | ||
[[Image:TA-dotted-line.png]] | [[Image:TA-dotted-line.png]] | ||
<pre> | |||
def myblock(tw, line_length): | |||
''' Draw a dotted line of length line_length. ''' | |||
try: # make sure line_length is a number | |||
line_length = float(line_length) | |||
try: # make sure | |||
except ValueError: | except ValueError: | ||
return | return | ||
if | if tw.canvas.pendown: | ||
dist = 0 | dist = 0 | ||
while dist+ | while dist + tw.canvas.pensize < line_length: # repeat drawing dots | ||
tw.canvas.setpen(True) | |||
tw.canvas.forward(1) | |||
tw.canvas.setpen(False) | |||
tw.canvas.forward((tw.canvas.pensize * 2) - 1) | |||
dist += ( | dist += (tw.canvas.pensize * 2) | ||
# make sure we have moved exactly line_length | |||
tw.canvas.forward(line_length - dist) | |||
tw.canvas.setpen(True) | |||
else: | else: | ||
tw.canvas.forward(line_length) | |||
return | return | ||
</pre> | |||
You can pass a list of up to three arguments to tamyblock.py as in the example below that converts the input to an rgb value. | You can pass a list of up to three arguments to tamyblock.py as in the example below that converts the input to an rgb value. | ||
[[Image:TA-rgb.png]] | [[Image:TA-rgb.png]] | ||
<pre> | |||
def myblock(tw, rgb_array): | |||
''' Set rgb color from values ''' | |||
tw.canvas.fgrgb = [(int(rgb_array[0]) % 256), | |||
(int(rgb_array[1]) % 256), | |||
(int(rgb_array[2]) % 256)] | |||
</pre> | |||
def myblock( | def myblock(tw, x): | ||
########################################################################### | ########################################################################### | ||
# | # | ||
Line 102: | Line 83: | ||
else: | else: | ||
X = x.upper() | X = x.upper() | ||
lc.heap.append(X) | tw.lc.heap.append(X) | ||
return | return | ||
def myblock( | def myblock(tw, x): | ||
########################################################################### | ########################################################################### | ||
# | # | ||
Line 114: | Line 95: | ||
# | # | ||
########################################################################### | ########################################################################### | ||
lc.heap.append(localtime().tm_hour) | tw.lc.heap.append(localtime().tm_hour) | ||
lc.heap.append(localtime().tm_min) | tw.lc.heap.append(localtime().tm_min) | ||
lc.heap.append(localtime().tm_sec) | tw.lc.heap.append(localtime().tm_sec) | ||
return | return | ||
def myblock( | def myblock(tw, x): | ||
########################################################################### | ########################################################################### | ||
# | # | ||
Line 125: | Line 106: | ||
# | # | ||
########################################################################### | ########################################################################### | ||
val = 0.3 * | val = 0.3 * tw.rgb[0] + 0.6 * tw.rgb[1] + 0.1 * tw.rgb[2] | ||
if x != 100: | if x != 100: | ||
x = int(x)%100 | x = int(x)%100 | ||
r = int((val*(100-x) + | r = int((val*(100-x) + tw.rgb[0]*x)/100) | ||
g = int((val*(100-x) + | g = int((val*(100-x) + tw.rgb[1]*x)/100) | ||
b = int((val*(100-x) + | b = int((val*(100-x) + tw.rgb[2]*x)/100) | ||
# reallocate current color | # reallocate current color | ||
rgb = "#%02x%02x%02x" % (r,g,b) | rgb = "#%02x%02x%02x" % (r,g,b) | ||
tw.fgcolor = tw.canvas.cm.alloc_color(rgb) | |||
return | return | ||
def myblock( | def myblock(tw, x): | ||
########################################################################### | ########################################################################### | ||
# | # | ||
Line 142: | Line 123: | ||
# | # | ||
########################################################################### | ########################################################################### | ||
tw.save_as_image(str(x)) | |||
return | return | ||
def myblock( | def myblock(tw, x): | ||
########################################################################### | ########################################################################### | ||
# | # | ||
Line 152: | Line 132: | ||
# | # | ||
########################################################################### | ########################################################################### | ||
if tw.mouse_flag == 1: | |||
if | |||
# push y first so x will be popped first | # push y first so x will be popped first | ||
lc.heap.append(( | tw.lc.heap.append((tw.canvas.height / 2) - tw.mouse_y) | ||
lc.heap.append( | tw.lc.heap.append(tw.mouse_x - (tw.canvas.width / 2)) | ||
lc.heap.append(1) # mouse event | tw.lc.heap.append(1) # mouse event | ||
tw.mouse_flag = 0 | |||
else: | else: | ||
lc.heap.append(0) # no mouse event | tw.lc.heap.append(0) # no mouse event | ||
====Device I/O==== | ====Device I/O==== | ||
Line 178: | Line 157: | ||
| screen brightness || /sys/devices/platform/dcon/backlight/dcon-bl/actual_brightness || OLPC XO | | screen brightness || /sys/devices/platform/dcon/backlight/dcon-bl/actual_brightness || OLPC XO | ||
|- | |- | ||
| light sensor || /sys/devices/platform/olpc-ols.0/ | | accelerometer || /sys/devices/platform/lis3lv02d/position || OLPC XO 1.75, 3.0 | ||
|- | |||
| light sensor || /sys/devices/platform/olpc-ols.0/level || OLPC XO 1.75, 3.0 | |||
|- | |||
| screen mode || /sys/devices/platform/dcon/monochrome || OLPC XO 1.75, 3.0 | |||
|- | |||
| charging || /sys/devices/platform/olpc-battery.0/power_supply/olpc-ac/online || OLPC XO | |||
|- | |||
| clock date|| /sys/devices/platform/pxa2xx-i2c.1/i2c-1/1-0068/rtc/rtc0/date || OLPC XO 1.75 | |||
|- | |||
| clock time|| /sys/devices/platform/pxa2xx-i2c.1/i2c-1/1-0068/rtc/rtc0/time || OLPC XO 1.75 | |||
|- | |||
|cpu temperature|| /sys/devices/platform/via_cputemp.0/temp1_input || OLPC XO 1.5 | |||
|} | |} | ||
Line 186: | Line 177: | ||
# The light sensor is only available on the XO 1.75 | # The light sensor is only available on the XO 1.75 | ||
device = '/sys/devices/platform/olpc-ols.0/ | device = '/sys/devices/platform/olpc-ols.0/level' | ||
if os.path.exists(device): | if os.path.exists(device): | ||
Line 196: | Line 187: | ||
tw.lc.heap.append(-1) | tw.lc.heap.append(-1) | ||
Look in /sys/devices on your computer to find other devices you may be able to access. | Look in /sys/devices on your computer to find other devices you may be able to access. | ||
You can also read events in /dev/input . Use the od (octal dump) command to inspect these events, eg | |||
sudo od /dev/input/event0 | |||
You can access the following events on the X0-1.75, (some on X0-1.0 -1.5) | |||
* accelerometer: /dev/input/event0 ??? | * accelerometer: /dev/input/event0 ??? | ||
* power button: /dev/input/event1 | * power button: /dev/input/event1 | ||
* lid switch: /dev/input/event2 | * lid switch: /dev/input/event2 | ||
* ebook: /dev/input/event3 | * ebook: /dev/input/event3 (XO-1.75) event4 (XO-1.0 - 1.5) | ||
* headphone jack: /dev/input/event7 | * headphone jack: /dev/input/event7 | ||
* microphone jack: /dev/input/event8 | * microphone jack: /dev/input/event8 | ||
* rotate, cursor, and game pad keys: /dev/input/event10 | * rotate, cursor, and game pad keys: /dev/input/event10 (XO-1.75) event6 (XO-1.0 - 1.5) | ||
* mouse : /dev/input/mice | |||
For example, the code below waits till the ebook switch state changes and pushes the status to the heap | |||
def myblock(tw, x): # ignores second argument | |||
import os | |||
devicestr='/dev/input/event3' #the ebook switch | |||
cmd='sudo chmod 777 {!s}'.format(devicestr) | |||
os.system(cmd) #caution! changing system file permissions | |||
fd = open(devicestr, 'rb') | |||
for x in range(12): | |||
fd.read(1) #does not return till the switch state changes | |||
tw.lc.heap.append( ord(fd.read(1))) #push ebook switch state to heap | |||
fd.close | |||
===Understanding the structure of the Turtle Art program=== | ===Understanding the structure of the Turtle Art program=== |