Adalo 条件付きで画像をランダムに表示させたい

【前提】
本件ではログイン機能は使用しないこととします

【実装したい機能】
①47都道府県の画像をランダムに表示する機能
②自分が住んでいる県を設定すると、そこから日帰りで行ける(※要定義)県の中からランダムに表示する機能

【今既にできていること】
①の機能は実装できています。
仕組みとしてはRAND関数を用いて、1から47までの範囲で乱数を発生させることで、それに応じた都道府県が表示されるというものです。
(1の場合は北海道、2の場合は青森県、・・のような形で)
image

テスト版が下記でございます。(1北海道・2青森・3岩手・4宮城・5秋田、のみ登録しています)

【できていないこと】
現状では②の機能を実装することができていません。
イメージとしては下記画像のように、

「日帰りモード」ボタンを押す
→ドロップダウンから住んでいる県を選ぶ
→「ランダムに表示する」ボタンを押す

といった流れを考えています。

日帰りの定義付けの方法として私が思いつく限りでは、
・「〇〇県であれば××県と△△県」というようなリレーションを作る
・Locationプロパティを用いて、住んでいる県から〇〇km以内にある県と定義する
といった方法があり得るのかなと考えております。(後者はAdaloの機能では無理かもしれません)

【質問したいこと】
②のような機能を実装することは可能でしょうか。

ロケーション機能というものがありまして、GoogleAPIを使って、ユーザーの現在位置を取得したり、2つの座標間の距離を計算したりできます。

ただ、直線距離だけで日帰りでいけるかどうかを定義するのは難しそうですね。あと、神奈川県といっても神奈川県のどことの距離を取るかによっても結果が変わっちゃいますしね:thinking:

マニュアルでリレーションするのも大分大変そうですけど、そのほうが確実な方法だとは思います!

「いいね!」 1

ご返信ありがとうございます。
日帰りの定義付はリレーションで行う方向で考えてみようと思います。

ただリレーションしたその後、どうやってランダム性を持たせて表示させるかという部分が完全に行き詰っています。

ドロップダウンで選んだ県から日帰りで行ける(とリレーションされている)県の画像を
リストで表示させることまではできたのですが、

こちらはあくまでリストの1番上だけを表示させてるに過ぎないため、
ランダムでは全くないですし、①の機能と違って選び直すこともできません。

下記質問への回答からヒントを得て、
毎回ランダムで変えることのできる抽選用の数字(抽選No)をプロパティで付与し、
抽選Noで高い順(又は低い順)にソートをかけることで、実質的なランダム性を持たせることができ、選び直すこともできるのではないかと考えましたが、
1アクションで全ての県の抽選Noをランダマイズする方法が分かりませんでした。

かなり惜しいところまでいってるような気がするのですが・・力及ばずといった感じです。
もし何か解決する方法がありましたらご教示いただけますと幸いです。
何卒よろしくお願い申し上げます。


Random Picker というコンポーネントがありまして、これで解決できるかと!

「いいね!」 1

申し訳ございません、ヒントを頂きたいです。

ランダムピッカーで解決できるというのは、
「1アクションで全ての県の抽選Noをランダマイズできない問題をランダムピッカーで解決できる」という意味か、「抽選Noとかややこしいことは考えず、ランダムピッカーの機能だけで、②の機能を実装できる」という意味か、どちらでしょうか?

このアプリを作り始めた際にまず、
ランダムピッカーを使って画像をランダムに表示させることを考えたのですが、
ログイン機能を使用しないと難しいという結論に至った結果、現在のような仕様になっております。
(そのため最初に前提として、ログイン機能は使用しないと記載させていただきました)

前提の認識が大きく誤っている可能性もあるため、
何かおかしなことを言っていましたらご指摘いただけますと幸いです。

作ってみました。一つのページで済まそうとると結構複雑になっちゃいますね:sweat_drops:
県を選択するページとランダム抽出するページ分けた方がいいかもですが、とりあえず:point_down:からクローンしてみてください!わからないところあればまたご質問くださいー

「いいね!」 1

ここの意図は、このリンク先で説明している

抽選No ・・毎回ランダムで変わる抽選用の数字

が変わらなかったということですか?

①CountTimeを1秒に設定する

②CountTimeが0になったら、抽選Noがランダムに 決まる

以降、つねに誰かが、初めて入ってきて、1秒以上滞在した場合に、数字が変わっていく。

という挙動になります。説明の意図間違っていたら申し訳ない:sweat_drops:

見本まで作っていただきありがとうございます。

クローンを確認しながら見よう見まねで作ってはみたのですが、なかなか上手くいかず、
自分の中で消化して活用するのに少し時間がかかりそうなので
不明点等洗い出した後に、改めて伺わせていただければと思います。

よろしくお願いいたします。

「いいね!」 2

ご回答ありがとうございます。

失礼いたしました、私のカウントダウンタイマーの扱い方がなっていなかっただけで
今やってみたところ実装することができました!

ランダム性を持たせるという意味では、百点満点の挙動なのですが
やはりカウントダウンタイマーを使用する都合上、選び直すたびに画面が遷移してしまうのが少しネックに感じております。

これについてはもうこういうものだと割り切るしかないでしょうか・・?
それとも私のセンスが無いだけで、画面遷移の回数を減らす余地はありますでしょうか。

何とかなりそうで、良かったです。

やはりカウントダウンタイマーを使用する都合上、選び直すたびに画面が遷移してしまうのが少しネックに感じております。

これは、一瞬でてくるカウントダウンタイマーのScreenのことですよね?
であれば、タイマーのページを専用でつくらなくても、選びなおすのページにタイマーをそのままおけば良いと思います。(すでにランダム表示で表示されたものは、再度フィルターされないので)

それで、選びなおすを押した時に、全く同じ構成のページに飛ぶ というのをすればどうでしょうか?

そうだったんですね、ここをちゃんと理解できていませんでした。
ありがとうございます!!

また行き詰ったら質問させてください。
ありがとうございました。

「いいね!」 1