Skip to content

Async Tasks Simplified is a small utility class, developed for Java (Android Studio) and C# (WPF & Avalonia UI). This class allows you to run code in Background (in another Thread) in a very simple, easy and clean way!

License

Notifications You must be signed in to change notification settings

marcos4503/async-tasks-simplified

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Async Tasks Simplified

Async Tasks Simplified is a small utility script that allows your application to execute code in another Background Thread easily, in addition to allowing your Background code to call code in the Main Thread easily. Currently, Async Tasks Simplified supports Java and C#!

Async Tasks Simplified allows you to run slow or time-consuming code in another background thread, such as network request code, file processing, changes to the UI based on timing or anything that would freeze your UI if executed in Main Thread. Async Tasks Simplified was based on but not copied from Android's AsyncTask class, which is currently marked as Obsolete by Google. Async Tasks Simplified was born with the idea of bringing a simple, clean and intuitive code to do background tasks.

How it works?

Async Tasks Simplified works much like similar to the standard Android AsyncTask class. After a few years the AsyncTask API was marked Obsolete by Google and the Async Tasks Simplified was created to be a simple replacement for the AsyncTask class. Initially I wrote the class for Java only, but here you will also see examples of use for other languages.

Firstly, you must create a new "AsyncTaskSimplified" object and then register the callbacks that will execute your code at each step of executing your Task, in addition to passing the start parameters. The start parameters are strings that you can define, which will be available in the start and execution stages of your code in the background. By registering all callbacks from all steps, and starting the Async Task, your code will be executed in the Background, and you will have Callbacks that will execute your code, before, during and after the code that is executed in the Background. It's quite simple!

In Java (Android Studio) only, the Async Tasks Simplified gives you the option to run your code in normal Threads or in native Java Executors, you are able to choose for example if your background code should run in Serial with other Async Tasks in a single Thread, or if your Async Task should run in parallel with other Async Tasks in a Thread Pool.

How to use?

First, clone this repository, and copy the AsyncTaskSimplified file that is in the Source-Code folder of this repository. Copy the file that refers to the language/framework you need. Then add it to your project. Now just follow the information below!

In Java, to start an Async Task, you can use the example code below...

new AsyncTaskSimplified(context, new AsyncTaskSimplified.Listener() {
        @Override
        public void onStartTask_RunMainThread(Context context, String[] startParameters) {
            //Run before background code, this will run on UI/Main Thread
        }

        @Override
        public String[] onExecuteTask_RunBackground(Context context, String[] startParameters, AsyncTaskSimplified.ThreadTools threadTools) {
            //Here is the code that should be executed in Background Thread.
            //This will return some result to the "onDoneTask_RunMainThread"

            //Make thread sleep
            threadTools.MakeThreadSleep(3000);

            //Report a new progress
            threadTools.ReportNewProgress("100%");

            //Return the result of this background code...
            return new String[] { };
        }

        @Override
        public void onNewProgress_RunMainThread(Context context, String progressOfBackground) {
            //Run when background thread (onExecuteTask_RunBackground) calls
            //"threadTools.ReportNewProgress()", this will run on UI/Main Thread
        }

        @Override
        public void onDoneTask_RunMainThread(Context context, String[] resultOfBackground) {
            //Run after Background Code finishes, this will run on UI/Main Thread
        }
    }, new String[]{"Parameter 1", "Parameter 2", "Parameter 3"})
    .Execute(AsyncTaskSimplified.ExecutionMode.ExecutorServiceThreadSingle);

Keep in mind that an Async Task goes through a total of 4 steps! See each of the steps now!

onStartTask_RunMainThread

This step is performed BEFORE your Background code starts executing. Furthermore, the code registered here runs on the Main Thread. In this callback, you also have access to the Context that started the Task and you also have access to the Start Parameters informed when starting the Task.

onExecuteTask_RunBackground

In this step, the code registered here is executed completely in another Thread that runs in the Background. The code registered here has easy access to the Context that started the Task, the Start Parameters informed when starting the Task and also has access to the ThreadTools belonging to that Task.

The ThreadTools is an object that only exists in the "onExecuteTask_RunBackground" event and with it you are able to make the Thread sleep for as many milliseconds as you want, and it is also capable of Reporting New Progress, which will activate the next step that you will see below.

The code registered here MUST return, at some point, a array of String containing the result of the code that was executed in the Background. This can be done easily just using something like return new String[]{ }.

onNewProgress_RunMainThread

This step is only executed, ONLY if during step "onExecuteTask_RunBackground", your code calls threadTools.ReportNewProgress("Example"); reporting a String containing progress. In this step, the registered code is executed in the Main Thread, and in this step you have access to the Context that started the Task and you also have access to the String that was informed when calling threadTools.ReportNewProgress("Example");.

onDoneTask_RunMainThread

This step is executed AUTOMATICALLY as soon as step "onExecuteTask_RunBackground" is completely finished, that is, when step "onExecuteTask_RunBackground" returns some result using a code such as return new String[]{ }.

At this stage, the registered code is also executed on the Main Thread. Furthermore, in this step the registered code has easy access to the Context that started the Task, and the array of Strings that was returned by the code in step "onExecuteTask_RunBackground".

HINT: Each method of this class has a description that can be seen in the auto complete of your IDE (like Android Studio) or in the class itself, so you can read the descriptions of the methods to better understand how each one works and its details.

And how to use it in C#?

Overall, Async Tasks Simplified in C# works exactly as it would in Java, with just a few syntax differences. The code shown above in Java would look like this in C#...

AsyncTaskSimplified asyncTask = new AsyncTaskSimplified(this, new string[] { "Parameter 1", "Parameter 2" });
asyncTask.onStartTask_RunMainThread += (callerWindow, startParams) => 
{
    //Run before background code, this will run on UI/Main Thread
};
asyncTask.onExecuteTask_RunBackground += (callerWindow, startParams, threadTools) =>
{
    //Here is the code that should be executed in Background Thread.
    //This will return some result to the "onDoneTask_RunMainThread"

    //Make thread sleep
    threadTools.MakeThreadSleep(3000);

    //Report a new progress
    threadTools.ReportNewProgress("100%");

    //Return the result of this background code...
    return new string[] { };
};
asyncTask.onNewProgress_RunMainThread += (callerWindow, newProgress) =>
{
    //Run when background thread (onExecuteTask_RunBackground) calls
    //"threadTools.ReportNewProgress()", this will run on UI/Main Thread
};
asyncTask.onDoneTask_RunMainThread += (callerWindow, backgroundResult) =>
{
    //Run after Background Code finishes, this will run on UI/Main Thread
};
asyncTask.Execute(AsyncTaskSimplified.ExecutionMode.NewDefaultThread);

HINT: Each method of this class has a description that can be seen in the auto complete of your IDE (like Visual Studio) or in the class itself, so you can read the descriptions of the methods to better understand how each one works and its details.

Support projects like this

If you liked this Class and found it useful for your projects, please consider making a donation (if possible). This would make it even more possible for me to create and continue to maintain projects like this, but if you cannot make a donation, it is still a pleasure for you to use it! Thanks! 😀


Donate


Created with ❤ by Marcos Tomaz

About

Async Tasks Simplified is a small utility class, developed for Java (Android Studio) and C# (WPF & Avalonia UI). This class allows you to run code in Background (in another Thread) in a very simple, easy and clean way!

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published