mirror of
				https://github.com/SimpleMobileTools/Simple-Draw.git
				synced 2025-06-05 21:59:17 +02:00 
			
		
		
		
	tweak the SaveImageDialog, make it more flexible
This commit is contained in:
		| @@ -369,13 +369,12 @@ class MainActivity : SimpleActivity(), CanvasListener { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun saveImage() { |     private fun saveImage() { | ||||||
|         SaveImageDialog(this, defaultExtension, defaultPath, defaultFilename) { |         SaveImageDialog(this, defaultPath, defaultFilename, defaultExtension, false) { fullPath, filename, extension -> | ||||||
|             savedPathsHash = my_canvas.getDrawingHashCode() |             savedPathsHash = my_canvas.getDrawingHashCode() | ||||||
|             saveFile(it) |             saveFile(fullPath) | ||||||
|             defaultPath = it.getParentPath() |             defaultPath = fullPath.getParentPath() | ||||||
|             defaultFilename = it.getFilenameFromPath() |             defaultFilename = filename | ||||||
|             defaultFilename = defaultFilename.substring(0, defaultFilename.lastIndexOf(".")) |             defaultExtension = extension | ||||||
|             defaultExtension = it.getFilenameExtension() |  | ||||||
|             config.lastSaveFolder = defaultPath |             config.lastSaveFolder = defaultPath | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -12,8 +12,8 @@ import com.simplemobiletools.draw.pro.helpers.SVG | |||||||
| import kotlinx.android.synthetic.main.dialog_save_image.view.* | import kotlinx.android.synthetic.main.dialog_save_image.view.* | ||||||
| import java.io.File | import java.io.File | ||||||
|  |  | ||||||
| class SaveImageDialog(val activity: SimpleActivity, val defaultExtension: String, val defaultPath: String, val defaultFilename: String, | class SaveImageDialog(val activity: SimpleActivity, val defaultPath: String, val defaultFilename: String, val defaultExtension: String, | ||||||
|                       callback: (savePath: String) -> Unit) { |                       val hidePath: Boolean, callback: (fullPath: String, filename: String, extension: String) -> Unit) { | ||||||
|     private val SIMPLE_DRAW = "Simple Draw" |     private val SIMPLE_DRAW = "Simple Draw" | ||||||
|  |  | ||||||
|     init { |     init { | ||||||
| @@ -27,6 +27,10 @@ class SaveImageDialog(val activity: SimpleActivity, val defaultExtension: String | |||||||
|                 else -> R.id.save_image_radio_png |                 else -> R.id.save_image_radio_png | ||||||
|             }) |             }) | ||||||
|  |  | ||||||
|  |             if (hidePath) { | ||||||
|  |                 save_image_path_label.beGone() | ||||||
|  |                 save_image_path.beGone() | ||||||
|  |             } else { | ||||||
|                 save_image_path.text = activity.humanizePath(folder) |                 save_image_path.text = activity.humanizePath(folder) | ||||||
|                 save_image_path.setOnClickListener { |                 save_image_path.setOnClickListener { | ||||||
|                     FilePickerDialog(activity, folder, false, showFAB = true) { |                     FilePickerDialog(activity, folder, false, showFAB = true) { | ||||||
| @@ -35,6 +39,7 @@ class SaveImageDialog(val activity: SimpleActivity, val defaultExtension: String | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|         AlertDialog.Builder(activity) |         AlertDialog.Builder(activity) | ||||||
|                 .setPositiveButton(R.string.ok, null) |                 .setPositiveButton(R.string.ok, null) | ||||||
| @@ -64,11 +69,11 @@ class SaveImageDialog(val activity: SimpleActivity, val defaultExtension: String | |||||||
|                             if (File(newPath).exists()) { |                             if (File(newPath).exists()) { | ||||||
|                                 val title = String.format(activity.getString(R.string.file_already_exists_overwrite), newPath.getFilenameFromPath()) |                                 val title = String.format(activity.getString(R.string.file_already_exists_overwrite), newPath.getFilenameFromPath()) | ||||||
|                                 ConfirmationDialog(activity, title) { |                                 ConfirmationDialog(activity, title) { | ||||||
|                                     callback(newPath) |                                     callback(newPath, filename, extension) | ||||||
|                                     dismiss() |                                     dismiss() | ||||||
|                                 } |                                 } | ||||||
|                             } else { |                             } else { | ||||||
|                                 callback(newPath) |                                 callback(newPath, filename, extension) | ||||||
|                                 dismiss() |                                 dismiss() | ||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user