Determinate ProgressBar ( 위의 예시에서 1번과 동일 )
Indeterminate ProgressBar ( 위의 예시에서 2번과 동일 )
현재 상태를 프로그래스바로 나타내고 싶었고 단색으로 하기엔 밋밋하기에
두 가지의 색을 이용해서 그라데이션을 줬다
간단하게 체크를 하기위해서 +, - 버튼으로 수치를 조작..
<style name="HorizontalProgressBarStyle" parent="Widget.AppCompat.ProgressBar.Horizontal">
<item name="android:layout_width">0dp</item>
<item name="android:layout_height">10dp</item>
<item name="android:max">100</item>
</style>
스타일을 한 번 사용해보고 싶었다
<color name="start">#78C268</color>
<color name="end">#338751</color>
사용된 색상
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<!-- 프로그래스바의 바탕 색깔 -->
<item android:id="@android:id/background">
<shape>
<gradient
android:angle="270"
android:centerColor="#E8E8EA"
android:centerY="1.0"
android:endColor="#E8E8EA"
android:startColor="#E8E8EA" />
<corners android:radius="20dp" />
</shape>
</item>
<!-- 프로그래스바의 진행률 색깔 선택 -->
<item android:id="@android:id/progress">
<clip>
<shape>
<gradient
android:angle="0"
android:centerX="0.25"
android:endColor="@color/end"
android:startColor="@color/start" />
<corners android:radius="20dp" />
</shape>
</clip>
</item>
</layer-list>
<ProgressBar
android:id="@+id/progress_bar"
style="@style/HorizontalProgressBarStyle"
android:layout_marginStart="24dp"
android:layout_marginTop="300dp"
android:layout_marginEnd="24dp"
android:progressDrawable="@drawable/progress_bar_green"
tools:progress="50" />
binding.run {
minus.setOnClickListener {
val num = progressBar.progress
progressBar.setProgress( num - 5 )
val restNum = (progressBar.max - progressBar.progress)
restKcal.setText( "${restNum} kcal" )
}
plus.setOnClickListener {
val num = progressBar.progress
progressBar.setProgress( num + 5 )
val restNum = (progressBar.max - progressBar.progress)
restKcal.setText( "${restNum} kcal" )
}
}
코드 부분에서는 볼 것이 없다 ..
버튼으로 단순하게 잘 동작하는지 보려고 했기 때문에 ....