20.4 turtle -- Tkのためのタートルグラフィックス

Tkプラットフォームで利用できます。

turtleモジュールはオブジェクト指向と手続き指向の両方の方法でタートルグラフィックス・プリミティブを提供します。グラフィックスの基礎としてTkinterを使っているために、TkをサポートしたPythonのバージョンが必要です。

手続き型インターフェイスでは、関数のどれかが呼び出されたときに自動的に作られるペンとキャンバスを使います。

turtleモジュールは次の関数を定義しています:

degrees( )
角度を計る単位を度にします。

radians( )
角度を計る単位をラジアンにします。

setup( **kwargs)
メインウインドウの大きさと位置を設定します。キーワードは:

例:

# デフォルトのジオメトリを利用: スクリーンの 50% x 50%、センタリング。
setup()  

# ウインドウを 200x200 ピクセル、スクリーンの左上。
setup (width=200, height=200, startx=0, starty=0)

# ウインドウをスクリーンの 75% x 50% にして、センタリング。
setup(width=.75, height=0.5, startx=None, starty=None)

title( title_str)
ウインドウのタイトルを title に設定します。

done( )
Tk のメインループに入ります。ウインドウは、クローズされるか、 プロセスが kill されるまで表示され続けます。

reset( )
スクリーンを消去し、ペンを中心に持って行き、変数をデフォルト値に設定します。

clear( )
スクリーンを消去します。

tracer( flag)
トレースをon/offにします(フラグが真かどうかに応じて)。トレースとは、線に沿って矢印のアニメーションが付き、線がよりゆっくりと引かれることを意味します。

speed( speed)
タートルのスピードを設定します。speed パラメータに適切な値は 'fastest' (ウェイト無し)、'fast' (5ms のウェイト)、 'normal' (10ms のウェイト)、'slow' (15ms のウェイト)、 それと 'slowest' (20ms のウェイト)です。 バージョン 2.5 で 新たに追加 された仕様です。

delay( delay)
タートルのスピードを delay に設定します。これは ms で与えます。 バージョン 2.5 で 新たに追加 された仕様です。

forward( distance)
distanceステップだけ前に進みます。

backward( distance)
distanceステップだけ後ろに進みます。

left( angle)
angle単位だけ左に回ります。単位のデフォルトは度ですが、degrees()radians()関数を使って設定できます。

right( angle)
angle単位だけ右に回ります。単位のデフォルトは度ですが、degrees()radians()関数を使って設定できます。

up( )
ペンを上げます -- 線を引くことを止めます。

down( )
ペンを下げます -- 移動したときに線を引きます。

width( width)
線幅をwidthに設定します。

color( s)
color( (r, g, b))
color( r, g, b)
ペンの色を設定します。最初の形式では、色は文字列としてTkの色の仕様の通りに指定されます。二番目の形式は色をRGB値(それぞれは範囲[0..1])のタプルとして指定します。三番目の形式では、色は三つに別れたパラメータとしてRGB値(それぞれは範囲[0..1])を与えて指定しています。

write( text[, move])
現在のペンの位置にtextを書き込みます。moveが真ならば、ペンはテキストの右下の角へ移動します。デフォルトでは、moveは偽です。

fill( flag)
完全な仕様はかなり複雑ですが、推奨する使い方は: 塗りつぶしたい経路を描く前にfill(1)を呼び出し、経路を描き終えたときにfill(0)を呼び出します。

begin_fill( )
タートルを塗りつぶしモードにします。 後には、対応する end_fill() 呼び出しが続かなければいけません。 さもないと、これは無視されてしまいます。 バージョン 2.5 で 新たに追加 された仕様です。

end_fill( )
塗りつぶしモードを終了し、図形を塗りつぶします; fill(0) と等価です。 End filling mode, and fill the shape; equivalent to fill(0). バージョン 2.5 で 新たに追加 された仕様です。

circle( radius[, extent])
半径radius、中心がタートルの左 radiusユニットの円を描きます。extentは円のどの部分を描くかを決定します: 与えられなければ、デフォルトで完全な円になります。

extentが完全な円である場合は、弧の一つの端点は、現在のペンの位置です。radiusが正の場合、弧は反時計回りに描かれます。そうでなければ、時計回りです。

goto( x, y)
goto( (x, y))
座標x, yへ移動します。座標は二つの別個の引数か、2-タプルのどちらかで指定することができます。

towards( x, y)
タートルの位置から点 xy までの線の角度を返します。 この座標は二つの別々の引数、2タプルまたは別のペンオブジェクトとして 指定できます。 バージョン 2.5 で 新たに追加 された仕様です。

heading( )
タートルの現在の向きを返します。 バージョン 2.3 で 新たに追加 された仕様です。

setheading( angle)
タートルの向きを angle に設定します。 バージョン 2.3 で 新たに追加 された仕様です。

position( )
タートルの現在の位置を (x,y) のペアで返します。 バージョン 2.3 で 新たに追加 された仕様です。

setx( x)
タートルの x 座標を x に設定します。 バージョン 2.3 で 新たに追加 された仕様です。

sety( y)
タートルの y 座標を y に設定します。 Set the y coordinate of the turtle to y. バージョン 2.3 で 新たに追加 された仕様です。

window_width( )
キャンバスウインドウの幅を返します。 バージョン 2.3 で 新たに追加 された仕様です。

window_height( )
キャンバスウインドウの高さを返します。 バージョン 2.3 で 新たに追加 された仕様です。

このモジュールはfrom math import *も実行します。従って、タートルグラフィックスのために役に立つ追加の定数と関数については、mathモジュールのドキュメントを参照してください。

demo( )
モジュールをちょっとばかり試しています。

exception Error
このモジュールによって捕捉されたあらゆるエラー対して発生した例外。

例として、demo()関数のコードを参照してください。

このモジュールは次のクラスを定義します:

クラス Pen( )
ペンを定義します。上記のすべての関数は与えられたペンのメソッドとして呼び出されます。このコンストラクタは線を描くキャンバスを自動的に作成します。

クラス Turtle( )
ペンを定義します。これは基本的に Pen() と同義です; Turtle は、Pen の空の派生クラスです。

クラス RawPen( canvas)
キャンバスcanvasに描くペンを定義します。これは``実際の''プログラムでグラフィックスを作成するためにモジュールを使いたい場合に役に立ちます。



Subsections
ご意見やご指摘をお寄せになりたい方は、 このドキュメントについて... をご覧ください。