三角関数を使って三角形を変形しよう
前回は三角形の上に位置する頂点の座標を移動させて、三角形を変形しました。
今回は三角形の下に位置する頂点の座標を移動させて、三角形を変形してみましょう。
三角形が回転しているように見えます。
三角形の左右の頂点を移動するプログラム
三角形の左右の頂点を移動するプログラムは、以下のようになります。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
### インポート import sys import math import pygame from pygame.locals import * ### 定数 WIDTH = 640 # 幅 HEIGHT = 400 # 高さ SIZE = 200 # 辺長 COG_X = int(WIDTH/2) # 重心X座標 COG_Y = int((HEIGHT-SIZE-SIZE/2)/2)+SIZE # 重心Y座標 ### モジュール初期化 pygame.init() ### 時間オブジェクト生成 clock = pygame.time.Clock() ### 画面設定 surface = pygame.display.set_mode((WIDTH,HEIGHT)) ### 三角形座標取得 apex_a = COG_X-int(math.cos(math.radians(90)) *SIZE), COG_Y-int(math.sin(math.radians(90)) *SIZE) apex_b = COG_X-int(math.cos(math.radians(210))*SIZE), COG_Y-int(math.sin(math.radians(210))*SIZE) apex_c = COG_X-int(math.cos(math.radians(330))*SIZE), COG_Y-int(math.sin(math.radians(330))*SIZE) ### 移動座標初期化 move_b = apex_b[0] move_c = apex_c[0] ### 移動距離取得 dist = apex_b[0]-apex_c[0] ### 無限ループ while True: ### 頂点移動分ループ for point in range(dist): ### 画面初期化 surface.fill((0,0,0)) ### 移動座標取得 apex_b = move_b-point, apex_b[1] apex_c = move_c+point, apex_c[1] ### 三角形表示 pygame.draw.polygon(surface, (255,255,255), (apex_a,apex_b,apex_c)) ### 画面更新 pygame.display.update() ### フレームレート設定 clock.tick(60) ### イベント処理 for event in pygame.event.get(): if event.type == KEYDOWN and event.key == K_ESCAPE: ### 終了処理 pygame.quit() sys.exit() |
プログラムを実行すると、三角形が変形します。