1
0

Simplifying the drawing of the progress bar (#96)

Co-authored-by: Maksym H <Maksym48@pm.me>
This commit is contained in:
Bektur 2022-09-09 00:28:25 +06:00 committed by GitHub
parent 4918f6a50f
commit cbb0bc2f53
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 42 additions and 85 deletions

View File

@ -119,8 +119,9 @@ class MainActivity : AppCompatActivity() {
binding.tvProgress.text = String.format(getString(progressMessage), progress)
binding.progressBar.progress = progress
// colorize the progress bar
val progressDrawable =
(binding.progressBar.progressDrawable as LayerDrawable).getDrawable(1)
val progressBarDrawable =
(binding.progressBar.progressDrawable as LayerDrawable).getDrawable(0)
val progressDrawable = (progressBarDrawable as LayerDrawable).getDrawable(1)
val color = Color.rgb(255 - progress * 2, progress * 2, 25)
progressDrawable.colorFilter =
BlendModeColorFilterCompat.createBlendModeColorFilterCompat(

View File

@ -1,27 +1,9 @@
<?xml version="1.0" encoding="UTF-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<shape>
<stroke
android:width="2.5dp"
android:color="#000000" />
<padding
android:bottom="3dp"
android:left="3dp"
android:right="3dp"
android:top="3dp" />
<corners android:radius="40dip" />
<gradient
android:endColor="#6a6a6a"
android:startColor="#6a6a6a" />
</shape>
</item>
<item>
<clip>
<shape>
<corners android:radius="40dip" />
</shape>
</clip>
</item>
<item
android:id="@android:id/background"
android:drawable="@drawable/progress_bar_bg" />
<item
android:id="@android:id/progress"
android:drawable="@drawable/progress_bar_fg" />
</layer-list>

View File

@ -0,0 +1,7 @@
<?xml version="1.0" encoding="UTF-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:drawable="@drawable/custom_progress_bar" />
<item
android:drawable="@drawable/progress_bar" />
</layer-list>

Binary file not shown.

After

Width:  |  Height:  |  Size: 272 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 294 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 222 B

View File

@ -5,14 +5,14 @@
<ProgressBar
android:id="@+id/progress_bar"
style="@style/Widget.MaterialComponents.LinearProgressIndicator"
android:layout_width="400dp"
android:layout_height="45dp"
android:layout_width="512dp"
android:layout_height="64dp"
android:layout_centerInParent="true"
android:layout_marginLeft="120dp"
android:layout_marginRight="120dp"
android:indeterminate="false"
android:max="100"
android:progressDrawable="@drawable/custom_progress_bar"
android:progressDrawable="@drawable/progress"
android:visibility="gone" />
<ProgressBar

View File

@ -546,80 +546,47 @@ void RenderingEngine::_draw_load_screen(const std::wstring &text,
video::ITexture *progress_img = tsrc->getTexture("progress_bar.png");
video::ITexture *progress_img_bg =
tsrc->getTexture("progress_bar_bg.png");
video::ITexture *progress_img_fg =
tsrc->getTexture("progress_bar_fg.png");
if (progress_img && progress_img_bg) {
if (progress_img && progress_img_bg && progress_img_fg) {
const core::dimension2d<u32> &img_size =
progress_img_bg->getSize();
#if !defined(__ANDROID__) && !defined(__IOS__)
float scale = RenderingEngine::getDisplayDensity();
scale = scale >= 1 ? scale : 1;
float density = RenderingEngine::getDisplayDensity();
float gui_scaling = g_settings->getFloat("gui_scaling");
float scale = density * gui_scaling;
u32 imgW = rangelim(img_size.Width, 256, 1024) * scale;
u32 imgH = rangelim(img_size.Height, 32, 128) * scale;
float imgR = scale;
#else
float imgRatio = (float) img_size.Height / img_size.Width;
u32 imgW = npot2(screensize.X / 2);
if (imgW > (screensize.X * 0.7) && imgW >= 1024)
imgW /= 2;
u32 imgH = imgW * imgRatio;
float imgR = (float) (imgW) / img_size.Width;
#endif
v2s32 img_pos((screensize.X - imgW) / 2,
(screensize.Y - imgH) / 2);
draw2DImageFilterScaled(
driver, progress_img_bg,
core::rect<s32>(img_pos.X, img_pos.Y, img_pos.X + imgW, img_pos.Y + imgH),
core::rect<s32>(0, 0, img_size.Width, img_size.Height),
draw2DImageFilterScaled(driver, progress_img_bg,
core::rect<s32>(img_pos.X, img_pos.Y,
img_pos.X + imgW,
img_pos.Y + imgH),
core::rect<s32>(0, 0, img_size.Width,
img_size.Height),
0, 0, true);
// rects for drawing a color progress bar
const static core::rect<s32> rects[] = {
core::rect<s32>( 4, 24, 5, 40),
core::rect<s32>( 5, 21, 6, 43),
core::rect<s32>( 6, 19, 7, 45),
core::rect<s32>( 7, 17, 8, 47),
core::rect<s32>( 8, 15, 9, 49),
core::rect<s32>( 9, 14, 10, 50),
core::rect<s32>( 10, 13, 11, 51),
core::rect<s32>( 11, 12, 12, 52),
core::rect<s32>( 12, 11, 13, 53),
core::rect<s32>( 13, 10, 14, 54),
core::rect<s32>( 14, 9, 15, 55),
core::rect<s32>( 15, 8, 17, 56),
core::rect<s32>( 17, 7, 19, 57),
core::rect<s32>( 19, 6, 21, 58),
core::rect<s32>( 21, 5, 24, 59),
core::rect<s32>( 24, 4, 488, 60),
core::rect<s32>(488, 5, 491, 59),
core::rect<s32>(491, 6, 493, 58),
core::rect<s32>(493, 7, 495, 57),
core::rect<s32>(495, 8, 497, 56),
core::rect<s32>(497, 9, 498, 55),
core::rect<s32>(498, 10, 499, 54),
core::rect<s32>(499, 11, 500, 53),
core::rect<s32>(500, 12, 501, 52),
core::rect<s32>(501, 13, 502, 51),
core::rect<s32>(502, 14, 503, 50),
core::rect<s32>(503, 15, 504, 49),
core::rect<s32>(504, 17, 505, 47),
core::rect<s32>(505, 19, 506, 45),
core::rect<s32>(506, 21, 507, 43),
core::rect<s32>(507, 24, 508, 40)
};
const video::SColor color(255, 255 - percent * 2, percent * 2, 25);
const video::SColor colors[] = {color, color, color, color};
for (const auto &i : rects) {
const s32 clipx = (percent * imgW) / 100;
core::rect<s32> r(
MYMIN(i.UpperLeftCorner.X * imgR, clipx), i.UpperLeftCorner.Y * imgR,
MYMIN(i.LowerRightCorner.X * imgR, clipx), i.LowerRightCorner.Y * imgR
);
if (r.getArea() <= 0)
break;
driver->draw2DRectangle(
video::SColor(255, 255 - percent * 2, percent * 2, 25),
r + img_pos, nullptr);
}
draw2DImageFilterScaled(driver, progress_img_fg,
core::rect<s32>(img_pos.X, img_pos.Y,
img_pos.X + (percent * imgW) / 100,
img_pos.Y + imgH),
core::rect<s32>(0, 0,
(percent * img_size.Width) / 100,
img_size.Height),
0, colors, true);
draw2DImageFilterScaled(driver, progress_img,
core::rect<s32>(img_pos.X, img_pos.Y,

Binary file not shown.

After

Width:  |  Height:  |  Size: 222 B