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

XamarinAdvent Calendar 2019

Day 13

俺のアプリがこんなにダークなわけがない

Last updated at Posted at 2019-12-12

タイトルの言い回しがもう古いかもしれませんが、最近の流行りがわからないのです・・・

こんなアプリを作ったよ

以前、続:どこまでショボいアプリがAppleの審査に通るのか試してみたで作ったアプリをiOSのダークモードに対応してみました。
このアプリは5W1Hで予言を表示するというアプリでした。

このアプリを

 ライトモードなら白背景
 ダークモードなら黒背景

にしてみました。

でも・・・ただ、それだけじゃつまらないよね・・・

ということで、ダークモードの時は「暗い奴」にすることにしました。

え、意味がわからない?
つまりこういうことです。

スクリーンショット 2019-12-13 0.07.23.png

これはライトモード。
色合いも美しく、シンプルで見とれてしまいますね。
内容もなんだかパリピな感じで明るい。

#ちなみに色はmaterialize-cssのカラーパレットから選びました
#CSSフレームワークのカラーパレットから選ぶと良い感じにしやすいです

さて、これをiPhoneをダークモードにして実行すると・・・

スクリーンショット 2019-12-13 0.06.57.png

なんということでしょう!内容が陰湿になりました!
見た目も中身もまさしくダークモードです!
OSのカラーモードでアプリの機能まで変えてしまうという、機能の趣旨を無視したアプリを作ることで世に一石を投じてみました。

動画で見るとこんな感じです。
ライトモードかダークモードかで言葉の辞書を変えてます。

movie.gif

こんな実装だよ

実はこの記事はXamarinのアドベントカレンダーに参加してるのでXamarinっぽいことも書きます。
ResouceDictionaryとDynamicResourceを使って、モードに応じて色を切り替えてます。

まずダークモードの判定は、Xamarin.iOS側に以下のような実装を書くことで取得できます。

//iOS側の処理(DependencyServiceで取得できるようにする)

        public bool IsDarkMode()
        {
            if (UIDevice.CurrentDevice.CheckSystemVersion(13, 0))
            {
                if (new UIViewController().TraitCollection.UserInterfaceStyle == UIUserInterfaceStyle.Dark)
                {
                    return true;
                }
            }
            return false;
        }

これをアプリの起動と再開時に取得します。

//App.xaml.cs

        protected override void OnStart()
        {
            SetTheme();
        }

        protected override void OnResume()
        {
            SetTheme();
        }

        private void SetTheme()
        {
            //1回スレッドを切らないとレジューム時に値がちゃんと取れなかった
            Device.BeginInvokeOnMainThread(() =>
            {
                IsDark = DependencyService.Get<IDeviceService>().IsDarkMode();
                if (IsDark)
                {
                    Resources["Background"] = Color.FromHex("000000");
                    Resources["TextColor"] = Color.FromHex("FFFFFF");
                    Resources["Accent"] = Color.FromHex("FFFF00");
                }
                else
                {
                    Resources["Background"] = Color.FromHex("fafafa");
                    Resources["TextColor"] = Color.FromHex("424242");
                    Resources["Accent"] = Color.FromHex("1565c0");
                }
            });
        }

最後のResoucesについてはApp.xaml側に書いてます。

<?xml version="1.0" encoding="utf-8"?>
<Application xmlns="http://xamarin.com/schemas/2014/forms" xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml" x:Class="Glorious.App">
    <Application.Resources>
        <ResourceDictionary>
            <Color x:Key="Background">#000000</Color>
            <Color x:Key="TextColor">#FFFFFF</Color>
            <Color x:Key="Accent">#FFFF00</Color>
        </ResourceDictionary>
    </Application.Resources>
</Application>

このResourcesを画面側で以下のような感じで参照してます。

<Button Text="{Binding Predict.ButtonText}"
                    WidthRequest="260"
                    Clicked="Handle_Clicked"
                    HorizontalOptions="Center"
                    Margin="0,30,0,0"
                    FontSize="20"
                    TextColor="{DynamicResource TextColor}" ←ここ
                    BackgroundColor="{DynamicResource Background}" ←ここ
                    BorderColor="{DynamicResource TextColor}" ←ここ
                    BorderWidth="1"
                    Padding="5,0,5,0"></Button>

あとはダークモードかどうかで表示する言葉の辞書を切り替えていました。

まとめ

以上、ダークモードとは何なのかを履き違えたアプリを作ってみました。

今回の内容とは全く関係ないですが、単純なアプリでも良いので1個作っておくと、こんな感じでちょっとした調査に使いまわせて良いですよ。

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