2
2

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 1 year has passed since last update.

ComposeのCornerSizeの指定

Last updated at Posted at 2023-12-22

初めに

ポート株式会社 サービス開発部 Advent Calendar 2023 22日目の記事です。

スクリーンショット 2023-12-22 10.34.15.png

今回は、細かいところではありますが、CornerSizeの指定方法の違いと注意することについて、解説していきます。

公式ドキュメントのandroidx.compose.foundation.shapeに書かれている内容がほとんどなので、こちらを参考にしてください。

結論

最初に、僕が伝えたいことを述べたいと思います。

これから解説するCornerSizeには、指定方法がいくつもあるので、どんな端末でもデザインを崩さないように、適切な指定方法を選んでいきましょう。

きっかけ

自分が携わっているプロジェクトでは、ButtonChipCardなどの多くのコンポーネントを角丸にしています。

アプリの動作確認を、複数端末で見比べながら行っていた時、ある端末ではデザイン通りのUIになっていましたが、別の端末ではデザイン崩れを起こしているのを見つけました。

この修正作業を行った際に、CornerSizeの仕様について調べたというのがきっかけです。

Shape

まず、AndroidにはShapeがあり、このクラスを指定するとコンポーネントの形が変化します。

AbsoluteCutCornerShape, CutCornerShape

角が削られた形を生成するクラスです。

スクリーンショット 2023-12-22 12.59.03.png

AbsoluteCutCornerShapeCutCornerShapeの違いは、右から左へのレイアウト方向(LayoutDirection.Rtl)のCornerSizeが考慮されているかどうかです。

4方向の角を指定するHelperメソッドを見てみるとわかりやすいです。

// left・rightの関係
fun AbsoluteCutCornerShape(
    topLeft: Dp = 0.dp,
    topRight: Dp = 0.dp,
    bottomRight: Dp = 0.dp,
    bottomLeft: Dp = 0.dp
): AbsoluteCutCornerShape

// start・endの関係
fun CutCornerShape(
    topStart: Dp = 0.dp,
    topEnd: Dp = 0.dp,
    bottomEnd: Dp = 0.dp,
    bottomStart: Dp = 0.dp
): CutCornerShape

AbsoluteRoundedCornerShape, RoundedCornerShape

角が丸くした形を生成するクラスです。

スクリーンショット 2023-12-22 13.00.34.png

CutCornerShapeと同様、AbsoluteRoundedCornerShapeRoundedCornerShapeの違いは、右から左へのレイアウト方向のCornerSizeが考慮されているかどうかです。

CircleShape

RoundedCornerShapeの一種で、円形に生成するクラスです。

スクリーンショット 2023-12-22 13.09.06.png

CircleShapeは、RoundedCornerShape(50)と同義になります。

CircleShape == RoundedCornerShape(50)

GenericShape

Pathを使用して、独自に形を生成することもできます。

例:台形

GenericShape { size, _ ->
    // 始点
    moveTo(size.width * 1 / 3, 0f)

    // 台形になるように線を引く
    lineTo(size.width * 2 / 3, 0f)
    lineTo(size.width, size.height)
    lineTo(0f, size.height)
    lineTo(size.width * 1 / 3, 0f)
}

スクリーンショット 2023-12-22 13.18.46.png

CornerSize指定

(ここから本題です。)

Composeであらかじめ用意されているShapeCutCornerShapeRoundedCornerShape)には、上述のようなHelperメソッドが用意されていて、そのメソッドを使用することでShapeを生成します。

今回は、RoundedCornerShapeを見ていきます。

fun RoundedCornerShape(corner: CornerSize): RoundedCornerShape

fun RoundedCornerShape(percent: Int): RoundedCornerShape

fun RoundedCornerShape(size: Dp): RoundedCornerShape

fun RoundedCornerShape(size: Float): RoundedCornerShape

fun RoundedCornerShape(
    topStart: Dp = 0.dp,
    topEnd: Dp = 0.dp,
    bottomEnd: Dp = 0.dp,
    bottomStart: Dp = 0.dp
): RoundedCornerShape

fun RoundedCornerShape(
    topStart: Float = 0.0f,
    topEnd: Float = 0.0f,
    bottomEnd: Float = 0.0f,
    bottomStart: Float = 0.0f
): RoundedCornerShape

fun RoundedCornerShape(
    topStartPercent: @IntRange(from = 0, to = 100) Int = 0,
    topEndPercent: @IntRange(from = 0, to = 100) Int = 0,
    bottomEndPercent: @IntRange(from = 0, to = 100) Int = 0,
    bottomStartPercent: @IntRange(from = 0, to = 100) Int = 0
): RoundedCornerShape

上記で挙げたメソッドは全て、引数の値をCornerSizeに変換し、RoundedCornerShapeに渡しています。

CornerSizeの指定方法

CornerSizeに変換する場合は、以下のメソッドを使用しています。

fun CornerSize(percent: @IntRange(from = 0, to = 100) Int): CornerSize

fun CornerSize(size: Dp): CornerSize

fun CornerSize(size: Float): CornerSize

3つの指定方法があり、おおまかに割合 or サイズ(絶対値) で指定します。

割合

0 ~ 100のIntを指定することで、コンポーネントサイズに対しての指定した割合で角サイズを決定します。

0よりも小さい場合または100よりも大きい場合は、エラーになります。

サイズ(絶対値)

サイズは、dppxの2つの指定方法があります。

androidx.compose.ui.unit.Dpを渡すとdp指定、Floatを渡すとpx指定になり、固定値で角サイズを決定します。

注意すること

CornerSizeの指定方法」でお気づきになるかもしれないですが、CornerSizeを指定する時、IntFloatで意味合いが違います。(当然ですね。。。)

多くの場合は、割合 == Floatのイメージだと思っているので、割合で指定したい時にFloatで渡しがちになります。(自分はそう思ってました。)

しかし、Floatで渡してしまうと、px指定になってしまうため、デバイス密度に依存してしまいます。
そのため、特定のデバイスではデザイン通りになっていても、他のデバイスでは角サイズが足りていないという現象が起きてしまいます。

例: CornerSize50fで指定する。

 Pixel 7 Pro Pixle 6a

終わりに

このように、端末によってデザインが変わってしまうのは、デザインを作成したデザイナーさんも意図していないことが多いので、どんな端末でもデザインを崩さないように、適切な指定方法を行うことを意識していきましょう!

今回の僕の場合では、UIテストを端末ごと(特にDpiが違う端末)で行い、デザインが正しいかをチェックすることを担保することでも回避できることなので、ComposeでのUIテストもちゃんと学んできたいなとおもえる出来事だったと思います。

参考

今回、参考にしていただいた記事です。

2
2
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
2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?