Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tasomaniac/DelayedProgress
ProgressDialog that waits a minimum time to be dismissed before showing. Once visible, the ProgressDialog will be visible for a minimum amount of time to avoid "flashes" in the UI.
https://github.com/tasomaniac/DelayedProgress
android android-library java prevents-flashes progress progress-bar progressbar progressdialog
Last synced: 2 months ago
JSON representation
ProgressDialog that waits a minimum time to be dismissed before showing. Once visible, the ProgressDialog will be visible for a minimum amount of time to avoid "flashes" in the UI.
- Host: GitHub
- URL: https://github.com/tasomaniac/DelayedProgress
- Owner: tasomaniac
- License: apache-2.0
- Created: 2014-04-11T09:27:18.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2022-09-07T15:30:16.000Z (over 2 years ago)
- Last Synced: 2024-11-12T21:08:22.596Z (2 months ago)
- Topics: android, android-library, java, prevents-flashes, progress, progress-bar, progressbar, progressdialog
- Language: Java
- Size: 258 KB
- Stars: 97
- Watchers: 13
- Forks: 21
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-android-ui - https://github.com/tasomaniac/DelayedProgress
- awesome-android-ui - https://github.com/tasomaniac/DelayedProgress
README
DelayedProgress
============================[![Android Arsenal](https://img.shields.io/badge/Android%20Arsenal-DelayedProgress-brightgreen.svg?style=flat)](http://android-arsenal.com/details/1/2117)
[![Build Status](https://travis-ci.org/tasomaniac/DelayedProgress.png?branch=master)](https://travis-ci.org/tasomaniac/DelayedProgress)
[![License](http://img.shields.io/:license-apache-blue.svg)](http://www.apache.org/licenses/LICENSE-2.0.html)ProgressBar and ProgressDialog that waits a minimum time to be dismissed before showing.
Once visible, the they will be visible for a minimum amount of time to avoid "flashes" in the UI.They extend platform version of them so that you can just replace all of your ProgressBar and ProgressDialog implementations quickly.
How does it look like?
----------------------Here is a demonstration of the usage in [GDG Android App](https://github.com/gdg-x/frisbee/).
As you can see here, on orientation change, the data is loaded quickly and has no progress indicator.![](https://cloud.githubusercontent.com/assets/763339/11843080/39e52c96-a410-11e5-81ea-f8c0ec623283.gif)
Usage
-----DelayedProgressBar
------------------`DelayedProgressBar` is an extension to `ProgressBar` that handles automatic delaying and prevents flashes in the UI.
You can create it programatically just like you do with `ProgressBar` or you can use it in your XMLs.
And you have to use `show()` and `hide()` functions instead of setting its visibility manually to have awesome delaying functionality.
Additionally we have `show(boolean animate)` and `hide(boolean animate)` that fades in and out the `ProgressBar`.
progressbar.show(true);
Lastly, if you want to do something when the animation ends, you can use the below function with endAction.
progressbar.show(true, new Runnable() {
@Override
public void run() {
//Do something
}
});progressbar.hide(true, new Runnable() {
@Override
public void run() {
//Do something
}
});DelayedProgressDialog
---------------------`DelayedProgressDialog` is an extension to `ProgressDialog` that handles automatic delaying and prevents flashes in the UI.
You can use it just like `ProgressDialog`. Just use `show()` and `dismiss()` appropriately and it will handle the rest.To create a `DelayedProgressDialog` with default timing values
DelayedProgressDialog.showDelayed(context, title, message, indeterminate, cancelable);
You can use `make()` to just create (without calling `show()`) it manually. This way you can modify it easily before calling `show()`DelayedProgressDialog.makeDelayed(context, title, message, indeterminate, cancelable);
And configureDelayedProgressDialog dialog = DelayedProgressDialog.make(...);
dialog.setMinDelay(2000);
dialog.setMinShowTime(500);
dialog.show();Download
--------```groovy
compile 'com.tasomaniac:delayed-progress:0.4'
```Snapshots of the development version are available in [Sonatype's `snapshots` repository][snap].
License
-------Copyright (C) 2015 Said Tahsin Dane
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License athttp://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.[snap]: https://oss.sonatype.org/content/repositories/snapshots/