キャンバスアプリからOpenAIのAPIを呼び出してみたので、その結果をメモ。
今回は画像生成APIを呼び出してみる。
今回使用するAPI
今回は「Create image」を呼び出してみる。
公式はこちら
![]()
Just a moment...
API Keyの取得
Power Automateの作成
前回同様、HTTPリクエストをPower Automateから送ってみる。
作成するPower Automateはこんな感じ。
data:image/s3,"s3://crabby-images/c0992/c099293ac42b09716e299b8a6e71aa855ea24473" alt=""
data:image/s3,"s3://crabby-images/c0992/c099293ac42b09716e299b8a6e71aa855ea24473" alt=""
引数として作成する画像のリクエスト文字列を受けて、
data:image/s3,"s3://crabby-images/ae6c0/ae6c010e727226fceda1d60b9bd486afad0b9ded" alt=""
data:image/s3,"s3://crabby-images/ae6c0/ae6c010e727226fceda1d60b9bd486afad0b9ded" alt=""
取得したAPIKeyと一緒にHTTPリクエストで投げてあげる。
※引数の詳しい説明は公式テキストを参照
data:image/s3,"s3://crabby-images/0347f/0347ffe9f16b88a88b2d2bf597308ae33bc8886c" alt=""
※引数の詳しい説明は公式テキストを参照
data:image/s3,"s3://crabby-images/0347f/0347ffe9f16b88a88b2d2bf597308ae33bc8886c" alt=""
後はレスポンスのJSONを解析して、作成してくれた画像のURLをPower Apps側に返して終了。
※dataは配列で返ってくるので、最初のURLを返してあげる。
※dataは配列で返ってくるので、最初のURLを返してあげる。
first(body('JSON_の解析')?['data'])?['url']
作成したときのスキーマはこんな感じだけど、アップデートもけっこう入るっぽいので、最新の情報は公式を参照。
{ "type": "object", "properties": { "created": { "type": "integer" }, "data": { "type": "array", "items": { "type": "object", "properties": { "url": { "type": "string" } }, "required": [ "url" ] } } } }
これでPower Automateの作成は完了。
Power Appsの実装
そしたら、作成したPower AutomateをPower Apps側から呼んでみる。
画面はこんな感じで、ボタンを押すとPower Automateからの戻り値が変数に入るようにする。
data:image/s3,"s3://crabby-images/025d1/025d105816d2e5b655ddae147e39111509142c81" alt=""
data:image/s3,"s3://crabby-images/025d1/025d105816d2e5b655ddae147e39111509142c81" alt=""
戻ってきた画像のURLを画像コントロールで表示するように設定して、実装完了。
data:image/s3,"s3://crabby-images/aadad/aadade05ab55aa350e4eff71b7530a8182c8c870" alt=""
data:image/s3,"s3://crabby-images/aadad/aadade05ab55aa350e4eff71b7530a8182c8c870" alt=""
動作確認
プロンプト「golden cat」でPower Appsを実行すると、このねこが返ってきて、
data:image/s3,"s3://crabby-images/71db7/71db77bff999019e98e94e6c1c2b36aa5c277517" alt=""
data:image/s3,"s3://crabby-images/71db7/71db77bff999019e98e94e6c1c2b36aa5c277517" alt=""
こんなプロンプトで画像を作成すると、このねこが返ってくる。
data:image/s3,"s3://crabby-images/f46c8/f46c8e5fe3babb090928e7f7e0e0821f2addad5e" alt=""
data:image/s3,"s3://crabby-images/f46c8/f46c8e5fe3babb090928e7f7e0e0821f2addad5e" alt=""
ということで、色々な画像を作れそうでちょっと楽しい。
コメント