# HG changeset patch # User David Barts # Date 1613597990 28800 # Node ID 5626557ac54279924a9a6fd506718773cd5ab959 # Parent 6ae738b8a814234de32b0c1c502e0ffa0b834dfd Add progress bar and a worker thread. Still way slow. diff -r 6ae738b8a814 -r 5626557ac542 app/src/main/java/com/bartsent/simpleresizer/EditImage.kt --- a/app/src/main/java/com/bartsent/simpleresizer/EditImage.kt Wed Feb 17 07:43:50 2021 -0800 +++ b/app/src/main/java/com/bartsent/simpleresizer/EditImage.kt Wed Feb 17 13:39:50 2021 -0800 @@ -13,6 +13,7 @@ import android.view.MenuItem import android.view.View import android.widget.EditText +import android.widget.ProgressBar import androidx.appcompat.app.AlertDialog import androidx.appcompat.app.AppCompatActivity import androidx.appcompat.widget.PopupMenu @@ -20,6 +21,7 @@ import com.bartsent.simpleresizer.lib.getScaledInstance import java.io.File import java.io.IOException +import kotlin.concurrent.thread import kotlin.math.roundToInt class EditImage : AppCompatActivity() { @@ -142,9 +144,16 @@ } val newBitmap = Bitmap.createBitmap((oldBitmap.width * factor).roundToInt(), (oldBitmap.height * factor).roundToInt(), oldBitmap.config) copyColorSpace(oldBitmap, newBitmap) - setImage(oldBitmap.getScaledInstance( - (oldBitmap.width.toDouble() * factor + 0.5).toInt(), - (oldBitmap.height.toDouble() * factor + 0.5).toInt())) + binding.progressBar.visibility = ProgressBar.VISIBLE + thread { + val newBitmap = oldBitmap.getScaledInstance( + (oldBitmap.width.toDouble() * factor + 0.5).toInt(), + (oldBitmap.height.toDouble() * factor + 0.5).toInt()) + runOnUiThread { + binding.progressBar.visibility = ProgressBar.INVISIBLE + setImage(newBitmap) + } + } } // is there any way to remember the last scale value? @@ -215,10 +224,16 @@ setRotate(deg.toFloat(), oldBitmap.width.toFloat()/2.0f, oldBitmap.height.toFloat()/2.0f) postTranslate((w - oldBitmap.width).toFloat()/2.0f, (h - oldBitmap.height).toFloat()/2.0f) } - Canvas(newBitmap).run { - drawBitmap(oldBitmap, rotater, null) + binding.progressBar.visibility = ProgressBar.VISIBLE + thread { + Canvas(newBitmap).run { + drawBitmap(oldBitmap, rotater, null) + } + runOnUiThread { + binding.progressBar.visibility = ProgressBar.INVISIBLE + setImage(newBitmap) + } } - setImage(newBitmap) } fun cancelClicked(view: View): Unit { diff -r 6ae738b8a814 -r 5626557ac542 app/src/main/res/layout/activity_edit_image.xml --- a/app/src/main/res/layout/activity_edit_image.xml Wed Feb 17 07:43:50 2021 -0800 +++ b/app/src/main/res/layout/activity_edit_image.xml Wed Feb 17 13:39:50 2021 -0800 @@ -72,4 +72,15 @@ app:layout_constraintStart_toEndOf="@id/cancel_button" app:layout_constraintTop_toBottomOf="@id/rotate_button" /> + + \ No newline at end of file