13
3

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.

NeosVR resoAdvent Calendar 2020

Day 3

[NeosVR] Logixを用いた外部データの取得と活用(パンツパッチから)[HTTP GET String]

Last updated at Posted at 2020-12-02

#はじめに

この記事は「NeosVR reso Advent Calendar 2020」の3日目です。
昨日は、@FLICKさんの「【NeosVR】回る20ルピー【基礎練習】」でした。

#対象&わかる人向けの説明

Neosで外部から情報を取りたい、という人向けです。

一例としてパンツ画像のガチャAPIから画像番号をJSONで取得後人力で番号を取り出し、
取得した番号を用いてパンツテクスチャのURLを生成します。Neosで使用できるAPIにはヘッダーを噛ませることができないため、Authorizationやcookieなどは扱いづらいです。

#Logixについて(始めたばかりの人向け)
Neosでは内部で機能を表す板のようなもの同士を、線をつなげることによりこちらが思うような動きをさせることができます。
一例で言えば、「表情を変えたいのだけどどうしたらいい?」というのに対して、下の様に流れを考えることができます。
「動かしたい人の取得」ー「コントローラの動きの取得」ー「シェイプキーに割り当て」

考えることができたら、あとはそれぞれを機能を表す板に変換していき、
それぞれをつないであげれば動かすことができます。
Photo in Home handgesture.png

#HTTP を利用したデータのやり取り
ブラウザの仕組みから話をしようとしましたがよくよく考えたらもっと丁寧に解説している人がたくさんいそうなのでそちらに投げることにします。良かったらここらへん読んでみてください。今回やるのはこの文章の中の1-3までです。Neosでは組み立てる部分は自分で行う必要があります。

今回使用するAPI

話は変わりますが、TenTEEEさんと呼ばれる方が過去380枚ほどキッシュちゃん用のパンツ画像を作成しては、毎日投稿していたタイミングがあり、その後も時々イベントがあるたびにパンツ画像を作成しています。
また、pythonの画像処理を用いて、本当に様々なキャラクターに対してパンツを変換して下さっています。すごいですね。その上、それらファイルについての参考情報をWeb上から取得できるようにしてくれています。
また、それら取得できるものについても特に取得制限などは設けず、優しく使ってね、と非常に緩めに設定してくれています。

API: https://labten.net/pantie-patch/api/
GitHub: https://github.com/TenteEEEE/quiche_pantie_patch
image.png

そのため、今回はこのAPIを使用し、無作為に画像を選択してくれるAPIを用いて画像のURLを生成することを最終目標としました。本当はPostも扱いたかったのですが、よさげなAPIがなかったので…

#実装例
今回考えるものは上に書いている通り、「無作為に画像を選択してくれるAPIを用いて画像のURLを生成する」ことです。ここからやりたい大まかなロジックとしては次の通りです.

  1. 「ガチャガチャAPIにアクセスする」
  2. 「取得できた番号から画像のURLを作る」
  3. 「画像を取得する」

そのため、ざっくりとそれぞれに分解してみました。

今回の肝となるのはあくまでGETなので、整形の部分についてはざっくりとだけ。
今回のAPIですが、まずそのままアクセスすると次のように返されます。

/
{
  "apps": [
    "dream",
    "convert",
    "suggest",
    "gacha",
    "zip"
  ]
}

今回使用するのはこのうち"gacha"になります。

/gacha/
[
  "10ren",
  "1ren"
]

1renを回してみましょう。

/gacha/1ren
[
  "0130.png"
]

画像のファイル名が取得できました(ランダムなので恐らく手元で取得したタイミングごとに番号が変わります)。あとはこのURLをそのままNeos上でも同じように取得する感じです。
Neos上では、[Get String]と呼ばれる板(「ノード」とよびます)を中心として、ざっくりとこんな感じにつないでいきます。Photo in Home PicSend.png

後はこんな感じに整形して…(多分もっとまともな方法ありますが、今回はこれで行いました。
Photo in Home parsing.png
画像URLとしてひっつけてあげれば完成です。
Photo in Home attachURL.png
最初の取得する際にタイマーで周期的に取得すると指定した周期で画像が変わるようになります。
Photo in Home timerset.png

#おわりに
記事にすると長いですが、手組してると5分コースになったりします。皆さんもぜひ外部からNeosへとデータをもってきて動かしてみてください。あとパンツ変えれるの楽しいよ。
今回の投稿で撮影・作成したノードが収録されているフォルダのURLです。インポートできる方は見てみてください。
neosrec:///U-kazu/R-597d3468-1397-4204-bb79-2daf4ab039ad

また、Neos内で聞いてくれれば実演しますので、もし見かけたら声かけてください。喜びます。

では。

13
3
2

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
13
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?