2017年1月9日月曜日

iOS版のLaiNESを作成

先日Androidで作成したLaiNESをiOSにも移植してみました。
https://github.com/suzukiplan/LaiNES-iOS

前の記事で書いているように、最初Android版と同様OpenGLを使う方向で作っていたのですが、如何せんパフォーマンスが悪いと感じたので、CoreAnimationLayerで映像バッファをダイレクトに書き込む方式(VGSと同じ方式)で実装するように作り直していたら丸1日掛かってしまった...(その間、デレステのイベントが走れずランキングが500位台から2000位のボーダーギリギリまで落ちてしまった)

結果的に、パフォーマンスはOpenGLよりも良くなりました。
知っていたことですが、やはりGPUレンダリングはピクセルバッファの描画に弱い。
CPUレンダリング最高です。
(※レンダリングにはピクセルバッファしか使わない勢限定ですが)

Android版と若干異なる点として、バーチャルパッドのデザインを変えました。

Android版のバーチャルパッドは、「普通に考えればこうなるよね」という形。
エミュレータだけでテストしていると、こういうダメなデザインになります。

一方、iOS版はこんな感じ。
一見すると野暮ったい。
ですが、実機で動かしてみると明らかにコチラの方が操作し易い筈です。

Android版のデザインのダメなところは、まず、左右のカーソルキーとA/Bボタンを同じ平行線上に並べている点ですね。
これだと、右カーソルキーを入れながらA/Bボタンを押すのがツライ。
具体的には、左親指が邪魔でA/Bが押し難くなる形になります。
この「右カーソルキーを入れながらA/Bボタンを押す」という操作は、例えば、横スクロールのアクションゲーム(スーパーマリオとか)で頻繁に使います。

そして、A/Bを横並びにしているのもマズイ。
Bを押そうとしてAを押してしまう頻度が高くなってしまうので。
この状態だと、例えば、スーパーマリオでBダッシュで助走をつけてジャンプといった操作で頻繁に誤操作が発生することになります。
縦並びにしてみたところ、誤操作はほぼ発生しなくなりました。
(ただし、スーパーファミコンのように4ボタンだと悩ましい)

2017年1月8日日曜日

iOSでもOpenGLを使ってみる

現在公開している LaiNES Android を単純に iOS へポーティング中。
https://github.com/suzukiplan/nes-view-ios/tree/open-gles-20
(追記: 諸般の事情で消しました)

Androidでは今回、描画をOpenGLにしてみたので、折角だからiOSも同じ方式を試しておこうと考えました。

iOSでOpenGLを使う場合、Viewのinterface宣言を

@interface NESView : GLKView <GLKViewDelegate>

という風にしました。
・UIViewではなくGLKView(#import <GLKit/GLKit.h>)にする
・GLKViewDelegateを設定

また、このNESViewのイニシャライザ(一応全部)の延長処理で、

self.context = [[EAGLContext alloc] initWithAPI:kEAGLRenderingAPIOpenGLES2];
[EAGLContext setCurrentContext:self.context];

という風にOpenGL/ES 2.0のコンテキストを設定。

あとは、AndroidのC++部分の実装と同じ形で、
・映像の頂点バッファを準備
・シェーダープログラムの作成
GLKViewDelegateのプロトコル(※)でピクセルバッファに対応するポリゴンの色を変更
などの処理を実装。

※これ
-(void)glkView:(GLKView *)view drawInRect:(CGRect)rect

OpenGLのインタフェースはC規約で、Androidのものと全く同じです。
だから、ソースコードはAndroidと共有できて良い感じなのですが、なんか微妙に遅い気がする。まだ、iOS固有の部分(core animation layerやUIView)にパフォーマンスの改善余地があるので何とも言えませんが。

あと、glViewportが想定通りに(というかAndroidと同じように)動いていない気がする。(これはコチラのバグかもしれません)

iOS的にはOpenGLよりもMetal推しだろうから、頑張ってOpenGL化するモチベーションがあまり沸かないんですよね。生Metal(?)を叩くのは結構面倒くさそうですが、Unityとかを使っていればAutomatic Graphics APIの項目をチェックするだけで簡単に使えたりします。

OpenGL自体結構deprecate方向に倒れつつある感じですしねぇ。
iOSならMetal、AndroidならVulkanにシフトしている流れです。
(Windowsについては相変わらずDirectXを魔改造する流れ)

Androidは例の如くOSバージョンのフラグメンテーション化が阻害要因になって普及は遅い筈です(本当、Androidなんか無くなれば良いのに)。Vulkanについては、そういった事情もあって聞き慣れない人も多いかもしれないので、(私もあまり詳しく無いですが)念のため補足すると、OpenGLと同じクロノスグループが開発しているもので、OpenGLは元々特定のハードウェアに依存しないように設計されたものですが、それが現代の最新のGPUには合わない(陳腐化した)ものになってしまったとかいう経緯で作られたものだったかと思います。「結局ハードウェアに依存してるじゃねーか」と突っ込みたくなりますね。しかし、実際その通りなので、その結果、より上位層のゲームエンジン(Unityなど)が直にOpenGLなどを叩きプラットフォーム依存を吸収する責務を負うという現代の潮流が出来上がったものと考えられます。その為、VulkanやMetalといった次世代のグラフィックスAPIはOpenGLと比べてローレイヤー寄りの設計になっているので、直に叩こうとするのはかなりツライですが、変態プログラマ諸氏にとっては格好の玩具だったりもします。

2017年1月6日金曜日

マリオランの価格考察

先日話題になったマリオランですが、一応私もプレイしました。
先週ぐらいにクリア済み。
当然ですが、クリアというのは、全ステージのカラーコインをコンプリートして、スペシャルステージやキノピオランの最終目標(ケーキの取得)も完了した状態です。
追加課金の無い完全落とし切りのゲームなので、恐らく追加コンテンツは発生しないのだろうと思います。
公式でもそういう発言をしているらしい記事があったので貼っておきます。
http://heavy.com/games/2016/12/super-mario-run-downloadable-content-additional-new-update-updates-maps-levels-items-nintendo/

このマリオランの価格設定(1200円)が「高すぎる」とかで少し話題になっているらしい。
参考記事:
任天堂マリオランは「高すぎる」 フォーブス記者も怒り爆発
任天堂 スーパーマリオランの1,200円はなぜ高い?

この意見が、ソシャゲなどを無課金でしかプレイしない人たち(いわゆる乞食勢)限定のものであれば、無視して問題ないと思うのですが、実のところ、課金をすることに全然躊躇しない私でも最初「ちょっと高いかな」と思ったりしたので、その原因について考察してみたいと思います。

なぜ、最初「ちょっと高いかな」と思ったのか。

それは、単純にワールドをアンロックすることに魅力を感じなかった為です。
フリーで提供されている3ステージを遊んでみて、これと同じのようなものの繰り返しだろうから、すぐに飽きるだろうなと。
一応、カラーコインを全部(ブラックコインまで)集めてみて、それ自体そこそこやり応えがあると思ったものの、それでも私ならすぐに全ステージ揃えてしまい飽きてしまうだろうと想像しました。
それだけのために1200円ということであれば、100%課金しなかった筈です。

そう思いつつ結局課金したのは、キノピオラリー(※)が楽しかった為です。
※他人のリプレイと競争してコインの獲得数で勝敗を決めるという対戦ゲーム
キノピオラリーは非同期対戦(対戦相手がリプレイ)のゲームなので、同期対戦のゲーム(例えば、デレステのライブパーティーというイベントなど)と比べて飽きがくるのが早そうだと思ったものの、1200円分は楽しめると思うことができたので、購入しました。

このことから、ゲーマー層(ゲームを極めるタイプの人)向けにはキノピオラリー、ライト層(カジュアルゲームなどを遊んで満足するタイプの人)向けにはステージアンロックがマリオランを購入させるための導線として考えられたモノなのだろうと想定できます。(他にも王国の建築要素など色々あったりするのかもしれませんが、そこら辺は専門外なので省略)

つまり、そこそこじっくりプレイしてみれば、1200円支払うことに納得感が得られる程度に楽しめるものだが、そこに至るまでの導線が弱いことが「1200円だと高いな」という印象を私に与えた原因だと言えます。

最初から有料であれば、何も不満無く気持ちよくプレイできた筈。

というのも、お金を最初に支払ってしまえば、それだけで「元を取る分まで遊び尽くそう」というモチベーションが生まれた筈なので。タダで手に入ったものだと、どうしても表面的なところで評価を下してしまいます。(購入導線の「強さ」みたいなことをチラホラ言ってますが、この「表面的なところ」だけでも買いたいと思わせるようなものが、要するに「強い」ということ)

また、フリーであるために、無課金勢によるレビューが沢山付き、購入する上で参考になる有益なレビュー(購入した上でのレビュー)が埋もれてしまうのも良くない。

free to play で出すのであれば、メインとなるコンテンツは全て基本無料でプレイできるようにした上で、サブコンテンツをアドオンにするなどで収益化の手段を作るしか無く、飽くまでもメイン・コンテンツに対して対価を求めるのであれば、基本有料にするのがベストな売り方だと思います。

つまり、今回1200円が高いと私に印象付けた根本的な原因は、本来「基本有料」で売るべき商品を「中途半端な基本無料」で売った為ではないかと考察しました。

pixel bufferのOpenGL/ESのロジックをC++化

昨日書いた記事で、Android版LaiNESの描画ロジックをOpenGL/ES2.0に書き換えることに成功しましたが、OpenGL/ESの実装をJavaで書くというしょっぱい作りになっていました。

AndroidのOpenGL/ESはNDK(C/C++)で書くことができるので、Javaで書くのはナンセンスです。

という訳で、サクッと Java → C++化。
https://github.com/suzukiplan/nes-view-android/pull/6

これで描画周りのパフォーマンスは大分良い感じになったと思います。

ただし、実機で動かした時の最大のボトルネック要因は描画周りではなくAPUエミュレータ(音関連)なので、その部分を何とかしたいところ。(これはLaiNESの問題で、VGSでは問題ないことだからあまり深追いするつもりはありませんが)

2017年1月5日木曜日

OpenGLで pixel buffer を60fps描画する方法

たまには技術的なことを書こう。

かなり以前、Android版VGSの描画をSurfaceViewからOpenGLに変更する試みをしたものの、60fpsのパフォーマンスが確保できず断念したことがあります。

VGSの描画処理は、

  1. 描画API(vgs_putSP等)を発行するとメモリ(システムメモリ)上に確保された8bit仮想VRAMに出力(OS非依存)
  2. VSYNC(垂直同期)の間隔で8bit仮想VRAMの内容を画面に出力(OS依存)
という流れで映像を画面に出力してます。

Android版VGSの上記2(OS依存部分)の実装は、RGB565のBitmapに8bit仮想VRAMの内容を(パレット変換をしながら)書き込み、それをSurfaceViewへCanvas#drawBitmapで描画する形になっています。

当時、これをOpenGL化するに当たって、毎フレームテクスチャを生成して描画するという方法を試しました。

しかし、テクスチャ画像の生成には結構時間がかかります。
また、システムメモリからGPUのメモリへの転送速度は物凄く遅い。
色々工夫して、50fps台ぐらいまで出せるようになったものの、それでは実用上問題がある(フレームレートだけでなく発熱量や消費電力も凄いことになる)ので、当時は結局OpenGL化を断念しました。

今回また、映像処理をOpenGL化することに再挑戦してみようと思います。

今回は、映像をテクスチャで表示するのではなく、1pixelを2ポリゴン(1つの四角形)で表現し、ポリゴンの色を変更することで映像を表示する仕組みを試してみることにします。

また、今回はVGSではなく、先日作ったLaiNESベースのファミコンエミュレータを使います。VGSのアーキテクチャはゲーム機エミュレータと同じ仕組みで作っているので、やっていることはファミコンと大差はありません。

以下、実際にOpenGL対応したAndroid版LaiNESを作成時の Pull Request です。
https://github.com/suzukiplan/nes-view-android/pull/4

ファミコンの場合、画素は256x240なので、pixel数=61,440 になります。
ポリゴン数 = pixel数 x 2 なので, 1フレーム辺り122,880ポリゴン。
60frame で描画するポリゴン数は, 7,372,800(737万2,800ポリゴン/秒)。

初代PlayStationの最大ポリゴン数のSCE公表値は、

  • 演算能力 = 150万ポリゴン/秒
  • 表示能力 = 36万ポリゴン/秒

とのことなので、この方式だと少々キツイ。
まぁ、初代PlayStationで動かす訳ではないですが。
ただ、もう少しポリゴン数を抑えた方が良い感じかなと。

そこで、上記のPull Requestでは、色情報の変化があったpixelのポリゴンのみ色を変更するようにしています。

これで適当なゲーム(某横スクロールアクションゲーム)を動かしてみて、1フレームあたりに更新されたピクセル数を測定した結果が下図です。
画面切り替わり直後などに最大更新が走りますが、ゲームプレイ中は多くても1万pixel未満の更新(これはスクロール時)で、スクロールしていない状態であれば100pixel未満の更新しか走らないようです。

常にスクロールしている状態(1万pixel更新)であれば、120万ポリゴン/秒ということになるので、これなら演算能力的には初代PlayStationでも耐えられそうです。(表示能力は追いつかなそうですが)

ナッツ&ミルクやドンキーコングみたいな固定画面アクションゲームなら余裕です。
まぁ、最近のスマホならフル更新(737万ポリゴン)であっても60fps保てそうな感じかと思います。(Android実機が手元に無くてエミュレータでしか動作確認してません)

2017年1月4日水曜日

デレステの上達方法

最近デレステのことしか書いていませんが、そういえばデレステは音ゲーなのに、音ゲーっぽいネタを書いてないな。という訳で、音ゲー部分の上達方法みたいなものを書いてみます。

参考までに私の腕前は、プレイ開始3日目でおねがいシンデレラのMasterをギリギリクリアできた程度で、プレイ開始から約4ヶ月経過した現在は、Master95曲中69曲フルコンしている感じです。(下手の横好きレベル)

音ゲーをじっくりプレイしたのは今回(デレステ)が初めてなのですが、一応ピアノをやっていたことがあるため、私のデレステ練習方法は基本的にピアノの練習方法の応用(ピアノで「こうやったら上手く出来るようになった」というネタが幾つかあるので、それをデレステ向けにカスタマイズしたもの)です。ちなみに、ピアノの腕前は平均律が弾ける程度でした(※今はもう弾けない)。

以下、我流の上達方法を項目毎に書いてみます。

①適正レベルより高めの曲のプレイを繰り返す
プレイ開始当初は、初回キャンペーンで獲得した無料石(2500個)を全て消費し尽くすつもりで、お願いシンデレラを繰り返しプレイしました。
自分の適正レベルより少し高めのレベルの曲(ギリギリクリアできるぐらいの曲)を繰り返しプレイすると上達スピードが早くて良い感じです。
やり込みの目安としては、ClearランクS(100回クリア)を取れるあたりを目標にすると良いでしょう。ちなみに、おねシンの次は(曜日限定だけど)咲いてJewel(Lv25)でそれをやりました。
しかし、一番難しい曲でも平常時はLv28までしか無いので、この方式で成長できるのは適正レベル(フルコンが狙えるレベル)26〜27辺りが限界になります。
イベントでLv30のMaster+曲が来れば、適正Lv28辺りにまで成長できるチャンスですが、Lv29のMaster+だとLv28のMasterとの差が少なすぎてあまり練習にならなかったりします。

②タップする指の接地面積を可能な限り小さくする
例えば、指の腹でタップするとミスし易くなります。
AppStoreでレビューを見てみると、「ロングノートが途中で切れる」「タッチしていないのにタッチ音が鳴る」といった不具合報告みたいなものをチラホラ見ますが、iPhone/iPadの場合、指の接地面積が大きすぎることが原因でそういった現象が起きている筈です。
タップするのは、置きプレイの場合は指先の肉の部分(爪を短めに切った状態で画面につかない程度の位置)にすれば、こういった問題は改善できます。(親指勢の場合は左手親指は右側面、右手親指は左側面の先端付近の肉の部分)

③椅子の高さを調整する
置きプレイ限定の事ですが、タッチしている時、腕が地面と並行になる程度の高さに椅子の高さを調整しましょう。
かなり重要なことです。
この高さでないと、②で書いている指先でのタップがやり難くなったりします。
また、脱力もし難くなるのでプレイしていて疲れやすくなります。
ピアノを習った経験がある人なら分かると思いますが、この腕が地面と並行になる程度の高さというのは、ピアノを演奏する時の椅子の高さのことです。
例えば、TOKIMEKIエスカレートやOrange Sapphireなどのフルコンが取れそうで取れないというレベルの人は、椅子の高さ調整をするだけでアッサリとフルコンが取れるかもしれません。

④単発ノートをスタッカート奏法で処理する
単発ノートは、タップした瞬間にポンと弾ませるようにする(スタッカート奏法でプレイする)ことで、次のノートの処理が迅速にできるようになり、その結果、Master+クラスの曲などで出てくる高速パッセージのようなノートでも簡単に処理できるようになります。

ただし、下手にスタッカート奏法でやろうとすると、ヘンな力みが入ってしまい逆効果になるので気をつけたいところです。以下のサイト(ピアノ向けのスタッカート奏法のやり方)あたりを参考にすると良いです。
https://allabout.co.jp/gm/gc/448849/all/

上記サイトで挙げられているポイントを、デレステに応用した形に修正すると、

  • 指先を立て、iPadに触れる面積をできるだけ小さくする
  • 指先からiPadまでの距離をできるだけ揃える
  • 指先が硬いイメージをもつ(指先が小さなメタルや陶器のようなイメージ)
  • 手首をぶらぶらと上下に振りすぎない
  • 指先だけに意識を集中させず、肘でコントロールするイメージをもつと過度に力むことを防げる
  • 肩を上げない(上半身をかたくしない)
  • 軽く跳ね上げられた反動で次のノートをタップするように意識する

という感じになります。
これらのことをしっかりと意識して、まずはProや易しめのMasterの曲で試してみると良いかと思います。

⑤使う指
デレステのキー配置を (1)(2)(3)(4)(5) とすると、ホームポジションを
(1) 左手の薬指
(2) 左手の中指
(3) 左手の人差し指 + 右手の人差し指
(4) 右手の中指
(5) 右手の薬指
という風にします。

稀に小指も使います(左右両方使いますが、どちらかといえば左の方が良く使う)が、小指についてはデレステ(5鍵)であれば、使っても使わなくても運動量に大差は無いかもしれません。(5鍵なら5指使えば必要十分ですが、スライドで動かした後のノート処理で移動量を少なくするために小指を使います)

親指は、遊びで片手プレイをする時にのみ使います。

デレステは2指(人差し指のみ or 親指のみ)でもプレイ可能な配置しか無いので、6〜8指だと過剰かもしれませんが、使う指を多くした方が、目的とするキーを押すために必要な運動量を減らせるため、処理可能な曲の幅が増えたり、体力(ゲームのスタミナではなくプレイヤー自身のリアルなスタミナ)の消耗を抑えられるといったメリットがあります。

一応、親指勢でLv30フルコンとかしている人も居ますが、そういったプレイ動画を見てみると、明らかに無用な力みが入っていたり、運動量が無駄に多い(バタバタしている)ことが分かります。体力がある内はそれでも良いのでしょうけど、エネルギーを無駄に使いたくなかったり、より難しい曲をフルコンできるようになりたいといった場合は、6〜8指でプレイしましょう。

⑥端末について
一応、デレステの曲は全て2本指で処理可能なので、iPhoneでもiPadでも問題ありませんが、適正Lv27以上を目指す場合はiPadじゃないと(私は)キツかったです。
というか、6〜8指でのプレイはiPadじゃないと、画面が小さすぎて無理があります。
最低でもiPad miniのサイズが必要で、できれば9.7インチ or 12インチの方が良いです。

⑦別の音ゲーをプレイする(適正Lv28以上)
デレステの Perfect の判定は、かなりガバガバです。
だからこそ初心者でも気持ちよくプレイできるのですが、Lv28以上だとこのガバガバさが仇になって正確なノート処理できずにGoodやBadになって切れてしまうことが多くなるように感じました。
要するに、デレステのガバガバ判定に慣れてしまっていることがマズイのではないかと。
これを矯正する方法として効果的なのは、デレステよりも判定がキツめの音ゲーに慣れることかなと考えました。
そこで、他の音ゲーを色々と試してみたのですが、スクフェス(ラブライブ)のPerfect判定がデレステよりはシビアで良い感じでした。

Lv27強〜Lv28以上の曲で「何故、GoodやBadになったのか分からない」という場面を多々経験したことがある人は、例えばスクフェスのExpertをall perfectでクリアなどを目標にプレイする練習を取り入れることで、繋がるようになるかもしれません。(これはまだ私が秘密のトワレでフルコンを取るために試行中の段階なので、これで本当に上達できるかは不明)

2017年1月1日日曜日

課金をするでごぜーます

気長にスカウトチケット(3000円払えば無料でSSRをゲットできるという例のアレ)のリセットを待とうと思っていたら、まるで見計らっていたかのように元旦にリセットされたので、速攻で購入しました。

で、誰をスカウトするのか。

候補は12/29の記事で書いた、
①仁奈(ともだちたくさん)
②高森(てづくりのしあわせ)
③及川(はつらつハーヴェスト)
④相葉(束ねた気持ち)
の4人に絞ることができます。

ステータス的には、
vo:5,781, da:3,817, vi:3,169
vo:5,791, da:3,161, vi:3,812
vo:5,816, da:3,866, vi:3,218
vo:5,858, da:3,184, vi:3,845

何も考えずに④相葉で良さそうです。
④相葉は、SRでまずまず使い込んでいたので、育成手間という面でも割とお得です。

育成手間というのは、現時点で付いているファン数の少なさのことで、ポテンシャルを解放するには最低でも50万人(1属性maxするのに必要な最低数)揃えることが必要で、1曲のプレイで得られるファン数は(90万点ぐらいなら)だいたい1000人前後だから、少なくとも500曲プレイする必要があるということになります。(同種キャラクタの配置で減らすこともできますが)

という訳で現時点のファン数の降順で並べると、
②>④>①>③
で、②高森が一番多い。

②高森のSRが判定強化なので、Pa曲のフルコンを狙ったプレイ(粘着プレイ)でよく使っていたから、自然とファン数が多くなった感じのようです。
①仁奈は初期の頃に使い込んでいましたが、R止まりだったため最近は全く出番が無く、③及川に至っては編成した覚えが全くないという感じです。

しかし、スコア狙いであれば、単純にステータスの高さや現時点のファン数だけで見るのは不味くて、なるべく同系統&他キャラクタの特技の発動間隔と被らないようにする事が大事らしい。

そこで、今回の候補の特技を見てみると、
11秒毎、高確率でしばらくの間、PERFECT/GREATのスコア17%アップ
13秒毎、高確率でかなりの間、PERFECT/GREATのスコア17%アップ
6秒毎、中確率でわずかな間、PERFECT/GREATのスコア17%アップ
7秒毎、高確率でわずかな間、PERFECT/GREATのスコア17%アップ
という具合。

それらと、現状最強構成(以下a〜d)の特技発動との相性で見てみます。
a. コンボボーナス / 18%up / 7秒ごと / 高確率 / わずかな間
b. コンボボーナス / 18%up / 6秒ごと / 中確率 / わずかな間
c. スコアアップ / 17%up / 13秒ごと / 高確率 / かなりの間
d. スコアアップ / 17%up / 9秒ごと / 高確率 / 少しの間

コンボボーナス(a, b)はスコアアップと並走できるので考慮不要ですが、スコアアップ(c, d)は被ると無駄打ちになります。
だから、②高森(13秒毎)はcと被るため、候補から除外できます。

他は・・・パッと見ではよく分からない。

そこで、理論値を計算できるサイトで、現状の最強構成でポテンシャル+特技Lvをmaxまで育てた時の流れ星キセキの理論値を計算してみたところ、
①仁奈: 1207663
②高森: 1195138
③及川: 1211879
④相葉: 1207014
という感じでした。

あれ?
ダントツで相葉だと予想していたのですが理論値だと仁奈より低いのか。
高森は想像通り低くなりましたが。
単純にステータスだけ見れば④相葉で、特技相性から見ても④相葉を選ばない理由は無いと思っていたのですが、分からないものですね。実際、多少アピールが低くても特技構成を良い感じに編成した時の方がフルコン時の平均スコアが気持ち高かった気がするので、そういうものなのかも。

そんな感じで、様々なことを総合的に判断した結果、
さば・・・ではなく、仁奈をスカウト。

あとは、今やっているイベントを只管走り続けて、最強編成のファン数をモリモリ上げれば良いでしょう。今回のイベントは1/9迄で、ちょうど私の正月休暇が1/9迄だから、恐らく(初の)2000位以内が狙えるかもしれません。

2000位以内=SSSランクが取れる目安ということで。
SSSの場合、誰でも参加できるイベントと違って参加条件がキツイので、イベントで2000位以内よりはSSSの方が単位時間当たりで見れば楽なはず。(SSSの場合、測定期間が長いので、イベントが短距離走ならSSSはマラソンというイメージ)

今のところ3桁以内で走っています。
3桁以内で走れているのは Flip Frop以来。
その Flip Fropでは2000位以内入賞を逃しましたが。(2021位)


今回はMaster+のフルコンも期間中に狙えると思うので、ハイスコアランキングでも初のトロフィーを狙えるかもしれません。(というか、ハイスコアを狙っていない安全な編成でMasterをフルコンしただけのスコアで、既に銅トロフィーが狙えそうな位置に居るような気がする)

イケると思っていたFlip FropのMaster+のフルコンを取り逃しているので、Master+のフルコンが本当にいけるのかは、結構怪しいところですが。(Flip Fropと違って前座で3曲やらないといけないイベントだから、更に怪しい)

色々な意味で Flip Frop の雪辱を果たす良い機会かもしれません。

合理的ではないものを作りたい

ここ最近、実機版の東方VGSの開発が忙しくて、東方VGSの曲追加が滞っています。 東方VGS(実機版)のデザインを作りながら検討中。基本レトロUIベースですがシークバーはモダンに倣おうかな…とか pic.twitter.com/YOYprlDsYD — SUZUKI PLAN (...