gihyo.jp » DEVELOPER STAGE » 連載 » ActionScript 3.0で始めるオブジェクト指向スクリプティング » 第16回 三角関数を使った楕円軌道のアニメーション

ActionScript 3.0で始めるオブジェクト指向スクリプティング

第16回 三角関数を使った楕円軌道のアニメーション

三角関数のcosとsin関数は,角度の変化に対して値がバネや波の動きのように増減する。これらの関数を使うと,円や楕円軌道を描くアニメーションがつくれる。

バネのように振動するアニメーション - cosとsin関数

楕円軌道の前に,一方向にバネのように揺れるアニメーションを作成してみよう。cosもsin関数も,0を中心に±1の間を値が振動のように増減する(図1)。

図1 角度の変化に対するcosとsin関数の値

図1 角度の変化に対するcosとsin関数の値

まずは,cos関数を使って,インスタンスを水平に揺らしてみる。使うメソッドはMath.cos()で,引数には角度となる数値を渡す。中心座標をステージ中央,揺れ幅を左右にそれぞれ100ピクセルとしよう。振幅はcos関数に掛け合わせ,中心座標はその値を加算すればよい。

  • 振動する水平座標=中心座標+cosθ×振幅

アニメーションさせるには,もちろんリスナー関数をインスタンスのDisplayObject.enterFrameイベント(定数Event.ENTER_FRAME)に登録する。振動させるインスタンスに記述するフレームアクションは,つぎのスクリプト1のとおりだ。

スクリプト1 インスタンスを水平に振動させるフレームアクション

// MovieClip: 振動させるインスタンス
var nRadian:Number = 0;
var nCenterX:Number = stage.stageWidth/2;
var nRadiusX:Number = 100;
addEventListener(Event.ENTER_FRAME, xMoveX);

function xMoveX(eventObject:Event):void {
  x = nCenterX+Math.cos(nRadian)*nRadiusX;
  nRadian += 0.1;
}

[ムービープレビュー]で確かめると,上記フレームアクション(スクリプト1)を記述したインスタンスが,バネの振動のように水平に揺れ動く(図2)。

図2 インスタンスが水平方向に揺れ動く

図2 インスタンスが水平方向に揺れ動く

つぎに,sin関数を使って,垂直方向に振動するアニメーションをつくってみる。用いるメソッドはMath.sin()で,考え方は水平方向の場合と同じだ(※1)。

  • 振動する垂直座標=中心座標+sinθ×振幅

インスタンスに記述するフレームアクションは,以下のスクリプト2のとおりだ。三角関数のメソッドをMath.sin()に変えたほか,参照するプロパティ,変数名や関数名などを修正した。ただし,角度の変数(nRadian)は同じである。

スクリプト2 インスタンスを垂直に振動させるフレームアクション

// MovieClip: 振動させるインスタンス
var nRadian:Number = 0;

var nCenterY:Number = stage.stageHeight/2;
var nRadiusY:Number = 100;
addEventListener(Event.ENTER_FRAME, xMoveY);
function xMoveY(eventObject:Event):void {
  y = nCenterY+Math.sin(nRadian)*nRadiusY;
  nRadian += 0.1;
}
※1)

振動する方向が水平ではcos関数,垂直だとsin関数と決まっている訳ではない。前掲図1からわかるように,cosとsin関数の揺れる値の変化の仕方(グラフのカーブの形状)は同じで,ただ増減の山と谷の位置が異なるに過ぎない。この山と谷の位置の違いを「位相」という。

なお,物理ではバネにつけた重りの揺れる動きを「単振動」と呼び,sin関数を使った式で表す(中心は原点とする)。

  • 重りの位置=振幅×sin(位相)

著者プロフィール

野中文雄(のなかふみお)

ソフトウェアトレーナー,テクニカルライター,オーサリングエンジニア。上智大学法学部卒,慶応義塾大学大学院経営管理研究科修士課程修了(MBA)。独立系パソコン販売会社で,総務・人事,企画,外資系企業担当営業などに携わる。その後,マルチメディアコンテンツ制作会社に転職。ソフトウェアトレーニング,コンテンツ制作などの業務を担当する。2001年11月に独立。Web制作者に向けた情報発信プロジェクトF-siteにも参加する。株式会社ロクナナ取締役(非常勤)。

URLhttp://www.FumioNonaka.com/

著書

  • ActionScript 3.0プロフェッショナルガイド

    ActionScript 3.0プロフェッショナルガイド(毎日コミュニケーションズ)

  • ActionScript 3.0辞典 [FlashPlayer 10/9対応]

    ActionScript 3.0辞典 [FlashPlayer 10/9対応](翔泳社)

コメント

コメントの記入

パスサポ

多数の情報処理技術者試験対策書籍の発行実績を誇る技術評論社がお届けする,資格試験合格サイト「めざせ! 情報処理試験 パスサポ」が開設されました。

ピックアップ

サクセスストーリーに続く,快適サーバー運用管理のヒント!

データの増大,煩雑な管理,システムダウン,セキュリティなど,迫りくる課題からシステム管理者の負担を軽くするポイントを解説します。

gihyo.jp インフラエンジニア情報局

ネットワークやITにかかわるあらゆる業種で必要とされるインフラエンジニアに向けた技術情報や心構え,その魅力について多角的に紹介。

テストエンジニア ステーション

いま,ITに関わるあらゆる開発業務で注目されつつあるテスト系エンジニアをターゲットにしたコンテンツサイトを展開します。

一行クイックアンケート

gihyo.jpで取り上げてほしいネタは?

※検索はページ右上の検索ボックスをご利用ください。

その他の連載

2010年版SEO体得講座

本連載では,いまや企業サイトの戦略の1つとして欠かすことのできないSEOについて,最新トレンドからすぐに使えるTipsまでを紹介します。

小型Linuxサーバの最高峰 OpenBlockS 600活用指南

搭載メモリの増加,CPUクロックの向上など,あらゆる面が強化された期待の新モデルOpenBlockS 600。この記事ではOpenBlockS 600の紹介から,活用するためのさまざまなノウハウを紹介していきます。

はじめMath! Javaでコンピュータ数学

プログラミング言語入門者向けに,知っていると役立つ数学的トピックスを紹介します。簡単な演習問題と解説で,即活用できる知識を目指します。

教科書には載っていない ネットワークエンジニアの実践技術

ネットワークエンジニア,インフラエンジニアのトラブル対応には,時には「教科書通りにいかない」テクニックが必要となります。資格試験では得られないこうした実践的な技術について,実例を元に紹介します。

Googleケータイ,世に現る

2008年9月,Googleが中心となって開発されている「Android」を採用した携帯電話「T-Mobile G1」が発表されました。本連載ではT-Mobile G1を中心にGoogleケータイに迫ります。

モバゲーオープンプラットフォームに挑戦!――面白法人カヤック流モバゲーオープンプラットフォーム企画と開発のイロハ

2010年1月にリリースとなったモバゲーオープンプラットフォーム。その制作企業であるカヤックが,アイデアを企画に落とし込み,開発までのノウハウを紹介します。

プロトタイピングツールSketchFlowを用いた,Silverlightアプリ開発

SketchFlowプロトタイプ作成からアプリケーション開発までをExpression Blend 3を使って実践的に解説します。

Ubuntu Weekly Recipe

Ubuntuの強力なデスクトップ機能を活用するための,いろいろなレシピをお届けします。

連載一覧

gihyo.jp

  • DEVELOPER STAGE
  • ADMINISTRATOR STAGE
  • WEB+DESIGN STAGE
  • LIFESTYLE STAGE
  • SCIENCE STAGE
  • NEWS & REPORT

書籍案内

  • 新刊書籍
  • 書籍ジャンル一覧
  • 書籍シリーズ一覧
  • 新刊ピックアップ
  • ロングセラー
  • 電脳会議

定期刊行物一覧

  • Software Design
  • WEB+DB PRESS
  • Web Site Expert
  • 組込みプレス

最近のコメント