Power PlatformからStability AIのAPIにつなぎ、画像生成AI「Stable Diffusion」を使用して画像生成するアプリを作ったのでメモ。
今回使用するAPI
今回はSDXL1.0の「Text-to-image」を使用する。※価格が安いから
data:image/s3,"s3://crabby-images/34a55/34a55cee1070b2f542d56176f68ccbe8c260f1c5" alt=""
APIの詳細はこちら
![]()
Stability AI - Developer Platform
事前準備:Stability AIのAPIキーを取得
アカウントの作成が完了すると無料で25クレジットが毎月もらえる。
data:image/s3,"s3://crabby-images/7c371/7c371c4bba6a0c1a8ea36ee43fde23d5f4fbfb9c" alt=""
data:image/s3,"s3://crabby-images/7c371/7c371c4bba6a0c1a8ea36ee43fde23d5f4fbfb9c" alt=""
APIキーを発行して事前準備完了。
data:image/s3,"s3://crabby-images/742b0/742b0462a0045571dee8ea4c864b0354abcee502" alt=""
data:image/s3,"s3://crabby-images/742b0/742b0462a0045571dee8ea4c864b0354abcee502" alt=""
Power Automateの作成
今回Stability AIとの通信はPower Automateを使用。全体像はこんな感じ。
data:image/s3,"s3://crabby-images/0e27d/0e27d03140a43c694ce6904feacaf8fa323cc348" alt=""
data:image/s3,"s3://crabby-images/0e27d/0e27d03140a43c694ce6904feacaf8fa323cc348" alt=""
今回は実行時パラメータとして「プロンプト」のみを受け取るよう作成。
data:image/s3,"s3://crabby-images/a0c3e/a0c3e7282d1af1228d9e1c4229c3c39467c0cada" alt=""
data:image/s3,"s3://crabby-images/a0c3e/a0c3e7282d1af1228d9e1c4229c3c39467c0cada" alt=""
APIの呼び出し個所は以下のように設定。
data:image/s3,"s3://crabby-images/4029f/4029f3968c887665e173e2cce65c13bf76bb3ca2" alt=""
data:image/s3,"s3://crabby-images/4029f/4029f3968c887665e173e2cce65c13bf76bb3ca2" alt=""
POSTリクエストを以下のURIに対して、Headerに「authorization : APIキー」を設定して送る。
https://api.stability.ai/v1/generation/stable-diffusion-xl-1024-v1-0/text-to-image
Bodyはこちら。
※各値の詳しい説明は公式を参照。
※各値の詳しい説明は公式を参照。
{ "cfg_scale": 7, "height": 1024, "width": 1024, "sampler": "K_DPM_2_ANCESTRAL", "samples": 1, "steps": 30, "text_prompts": [ { "text": "【プロンプト】", "weight": 1 } ] }
そしたら公式を参考に「JSONの解析」で戻り値を解析し、画像(base64)とSeed値を返す。
// 画像(1枚目のみ) first(body('JSON_の解析')?['artifacts'])['base64'] // Seed値 first(body('JSON_の解析')?['artifacts'])['seed']
これでPower Automateの作成は完了。
Power Appsの作成
最後にPower Apps側の作成。
まず画面にテキストボックスとボタン、画像コントロールを用意して、ボタンのOnSelectで先ほどのPower Automateを呼び出す式を書く。
data:image/s3,"s3://crabby-images/6391d/6391de798b728cf6b7c9c810214353bd96c285f0" alt=""
data:image/s3,"s3://crabby-images/6391d/6391de798b728cf6b7c9c810214353bd96c285f0" alt=""
画像コントロールのImageプロパティに、Power Automateから取得した画像のbase64値を設定し、その先頭に文字列「data:content/type;base64」を付与すれば構築完了。
data:image/s3,"s3://crabby-images/53ee9/53ee9e125ed26fd62c31413f84933dcfef80668d" alt=""
data:image/s3,"s3://crabby-images/53ee9/53ee9e125ed26fd62c31413f84933dcfef80668d" alt=""
実行してみるとこんな感じで画像を生成してくれる。
data:image/s3,"s3://crabby-images/6f7f7/6f7f72d89e878e3a45979b6de4499d60d8418442" alt=""
data:image/s3,"s3://crabby-images/6f7f7/6f7f72d89e878e3a45979b6de4499d60d8418442" alt=""
わざわざPower Appsから呼び出すことはあんまりないんだろうけど、簡単に構築できるのは嬉しい。