視覚的な例は、この種の質問に役立ちます。
ボイラープレート
グラデーションを作成するには、res / drawableにxmlファイルを作成します。私は私のmy_gradient_drawable.xmlを呼び出しています:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<gradient
android:type="linear"
android:angle="0"
android:startColor="#f6ee19"
android:endColor="#115ede" />
</shape>
いくつかのビューの背景に設定します。例えば:
<View
android:layout_width="200dp"
android:layout_height="100dp"
android:background="@drawable/my_gradient_drawable"/>
type = "linear"
設定しangle
用linear
タイプ。45度の倍数でなければなりません。
<gradient
android:type="linear"
android:angle="0"
android:startColor="#f6ee19"
android:endColor="#115ede" />
data:image/s3,"s3://crabby-images/6884e/6884ecc6fb967c1cfc34d405e4becfe0d4bedecb" alt="ここに画像の説明を入力してください"
type = "radial"
設定しgradientRadius
用radial
タイプ。使用%p
するとは、親の最小寸法のパーセンテージを意味します。
<gradient
android:type="radial"
android:gradientRadius="10%p"
android:startColor="#f6ee19"
android:endColor="#115ede" />
data:image/s3,"s3://crabby-images/8eec9/8eec90d8a60157b0675a894825c104bbc4fe2637" alt="ここに画像の説明を入力してください"
type = "sweep"
なぜ誰かがスイープを使用するのかはわかりませんが、完全を期すために含めています。角度を変更する方法がわからなかったので、1つの画像のみを含めています。
<gradient
android:type="sweep"
android:startColor="#f6ee19"
android:endColor="#115ede" />
data:image/s3,"s3://crabby-images/339b2/339b231fbc905aff9318d68ac284258fe433b5de" alt="ここに画像の説明を入力してください"
センター
スイープまたはラジアルタイプの中心を変更することもできます。値は、幅と高さの割合です。%p
表記法も使用できます。
android:centerX="0.2"
android:centerY="0.7"
data:image/s3,"s3://crabby-images/6d592/6d592a1323163ef4643d7b616cfc6cdcc3627eb4" alt="ここに画像の説明を入力してください"