0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

Pepper SDK入門(31) AnimateとAnimationでPepperのanima(魂)を疑似体験する

Last updated at Posted at 2021-09-21

#はじめに
今回はQiChat MANIAXではなく、Pepper SDK入門の続きです!
腕や頭部、腰、ひざの他、ホイールを使った動きや事前に定義した軌道上を移動するような動作を作るAnimate、及びAnimationについて書いていきます✏️
アニメーションはタブレットにもスマートスピーカーにもないもので、PepperをPepperたらしめるものすごーーーーく大事な機能です!!!!
基本的な実装はこちらになります↓

//アニメーションのオブジェクトを作成
Animation myAnimation = AnimationBuilder.with(qiContext)
                                      .withResources(R.raw.dog_a001)
                                      .build();

//アクションをビルド
Animate animate = AnimateBuilder.with(qiContext)
                                .withAnimation(myAnimation)
                                .build();

//アクションを非同期に実行
animate.async().run();

#着ぐるみには中身がいるし、アニメーションにはアニメーションをするためのファイルがある⚙🧸
AnimationでPepperを鏡の中のマリオネットにしましょう!使用されるファイルの拡張子は.qianimと.pmtです。

Animation Browserの回も参考にしてください。

また、Animationではラベルを取り扱うことも可能です!
ラベルを使用すれば、Animation内の指定のタイミングで発話や画面表示が指定できます。

Animation animation = AnimationBuilder.with(qiContext)
                                      .withResources(R.raw.dog_a001)
                                      .build();

Animate animate = AnimateBuilder.with(qiContext)
                                .withAnimation(animation)
                                .build();

animate.addOnLabelReachedListener((label, time) -> {
    //ラベルが到達した場合の処理
});

これはGitのMastering Animation labelsで体験できます🏷

#使用例
##.qianmファイルの場合
Animation Timelineとも呼ばれ、腕と頭部、腰、ひざ12を使った動作を行います。日常的な挨拶の動作や動物の真似、ダンスなど、種類は様々です🎁🎨
アニメーションはアニメーションライブラリから選ぶ他に一から作成することも、Animation Editorで編集することも可能ですので、多様なアニメーションが実現します🩰

VID_20210806_125106.gif$\tiny{aiboに対抗している様子}$
##.pmtファイルの場合
Animation Trajectoryとも呼ばれ、Pepperが移動する軌道を作成することができます。
.pmtファイルについてはTrajectory Editorの回を参考にしてみてください。

#石橋を殴って渡ろう~Pepperの安全制御について~
Pepperには安全制御機能が搭載されています。そのためアニメーション実行時に障害物にぶつかりそうになると、アニメーションは部分的に実行されることがあります。移動の際も同様に、移動経路上に障害物があると、該当部分の移動がカットされる場合があります。

全体的なアニメーションの実行時間は変わらないため、障害物を回避すると目的地に到達する十分な時間が確保されない場合があり、その際Pepperは全ての軌道を辿ることなく動作を停止します。時は吝嗇なのです。

#AnimateとGoToの二択について🦀
Pepperの動作はAnimateでもGoToでも作成することができます。
Animateでは障害物回避の動作を除いて安定した軌道を作ることが可能ですが、特定の地点に移動させる場合はGoToを使うのが良いでしょう。GoToであれば障害物をよけつつ、目的地まで移動することができます。
ダンスやボディーランゲージ、決まった動きをさせたい場合は、Animateの使用がおすすめです。使用目的に合わせて選びましょう🦉🌆

#あとがき
今回はPepperSDKforAndroidのAnimateAnimationを参考に書かせていただきました。
さらに詳しい情報は、AnimateのAPIドキュメントAnimationのAPIドキュメントを参照してください。

次回のPepperSDK入門はトラベルのアレじゃないGoToです🧳それでは!🧨

  1. ひざを使うとモーターホットが発生しやすくなります。負担が大きいため、あまり使用しないのがおすすめです。

  2. 腰、ひざを使うとホイールが浮くような動作になることがあります。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?