3
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 5 years have passed since last update.

Low-Code/No-CodeAdvent Calendar 2018

Day 7

PowerAppsでスコア用のフォントを表示する。

Posted at

単に数字を表示するのではなくちょっと気の利いたフォントで数字を表示したいときに使える方法です。
単純に数字の画像を切り替えるだけなんですけどね♪

準備

0~9のスコア用の画像をメディアに取り込んでおきます。

こんな感じ
image.png

方法1:Switchを使って切り替える

一番理解しやすいやり方だと思います。

メディアから画像を桁数分だけ挿入し、各桁のImageプロパティに以下の設定を行います。

image.png

Imageプロパティ
一の位 = Switch(Mod(score,10),0,dNumber0,1,dNumber1,2,dNumber2,3,dNumber3,4,dNumber4,5,dNumber5,6,dNumber6,7,dNumber7,8,dNumber8,9,dNumber9)
十の位 = Switch(Mod(RoundDown(score/10,0),10),0,dNumber0,1,dNumber1,2,dNumber2,3,dNumber3,4,dNumber4,5,dNumber5,6,dNumber6,7,dNumber7,8,dNumber8,9,dNumber9)
百の位 = Switch(Mod(RoundDown(score/100,0),10),0,dNumber0,1,dNumber1,2,dNumber2,3,dNumber3,4,dNumber4,5,dNumber5,6,dNumber6,7,dNumber7,8,dNumber8,9,dNumber9)

Scoreの値を変更することで画像が切り替わります。
スコア加算1.gif

方法2:スコア用の画像をコレクションに保存して呼び出す

Switchを使わない方法です。

ScreenのOnVisibleでもボタンのOnSelectでもよいのでコレクションを作ります。今回はnumImagesというコレクションにします。

ClearCollect(numImages,{id:0,image:dNumber0},{id:1,image:dNumber1},{id:2,image:dNumber2},{id:3,image:dNumber3},{id:4,image:dNumber4},{id:5,image:dNumber5},{id:6,image:dNumber6},{id:7,image:dNumber7},{id:8,image:dNumber8},{id:9,image:dNumber9})

コレクションの一覧を確認すると確かに生成されています。
image.png

あとは各桁のImageプロパティに以下の設定を行うだけです。

Imageプロパティ
一の位 = LookUp(numImages, id=Mod(score,10),image)
十の位 = LookUp(numImages, id=Mod(RoundDown(score/10,0),10),image)
百の位 = LookUp(numImages, id=Mod(RoundDown(score/100,0),10),image)

問題なく動きますね。
スコア加算2.gif

方法3:せっかくだから表示用の画像をギャラリーで作る。

方法1と方法2では表示用の画像を3枚挿入しましたが、それがちょっともぞもぞする場合はギャラリーを使います。

まずはscoreを桁ごとに分けてコレクションを作成します。scoreNumとします。

ClearCollect(scoreNum,{id:0,num:0},{id:1,num:0},{id:2,num:0})

こんなのできました。
image.png

ギャラリーを挿入してItemsにscoreNumを設定します。その際、idの降順になるように設定します。
ギャラリーのレイアウトは横方向を選びます。

Gallery
Items = Sort(scoreNum,id,Descending)

また、ギャラリー内の画像のImageを以下のように設定します。

Image
Image = LookUp(numImages,id=ThisItem.num,image)

で、ちょっと横幅を調整するとこんな感じになります。
image.png

あとはscoreを増減させたときにscoreNumをUpdateIfで更新するだけになります。

Button.OnSelect
UpdateContext({score:score+1});
UpdateIf(scoreNum,true,{num:Mod(RoundDown(score/10^id,0),10)})

こちらの動作も他と比べ問題なさそうですね。
スコア加算3.gif

少しぐらい早くしてもそれっぽくスコアが表示されます。
スコア加算.gif

お好きな実装方法でお試しください。

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