in this chapter, we will learn about android renderscript. usually the apps on android are designed as to consume as minimum resources as possible. but some applications like some 3d games need high level processing on android.
to provide these applications high performance android introduced the renderscript. it is android based framework which is used for running applications that perform very highly computational tasks. the development on this framework is done in native development kit(ndk) provided by android. renderscript is extremely useful for applications which performs following types of actions −
- 3d rendering
- image processing
- computational photography
- computer vision
how renderscript works
renderscript framework is basically based on data parallel computation. it distributes your application workload on all the processors available on your device like multi-core cpus or gpus.
this parallel distribution of workload frees the programmer from the tension of load balancing and work scheduling. you can write more detailed and complex algorithms for your app without the worry of computational power.
how to begin
to use the renderscript framework you must have following two things −
- a renderscript kernel
- renderscript apis
a renderscript kernel
a kernel is a program which manages data processing instructions and manage workload on central processing units.a kernel is a fundamental part of the operating system.
similarly to run the renderscript framework we need a written script named as kernel to manage all the data processing requests from our app and utilize more features of the android os provided by the ndk and as mentioned earlier that the development of renderscript is done in the native development kit of android.
the kernel script is written in c-99 standard of c-language. this standard was before the development of c++. a renderscript kernel script file usually placed in .rs file. each file is called as a script. a renderscript kernel script can contain following elements −
sr.no | elements & description |
---|---|
1 |
a language declaration it declares the version of renderscript kernel language used in this script. |
2 |
a package declaration this declaration names the package name of the java class which will be affected by this kernel code. |
3 |
invokable functions you can call these invokable functions from your java code with arbitrary arguments. |
4 |
script global variables these are just like the variables defined in c and c++ programming language. you can access these variables from your java code. |
following is the sample code of a kernel −
uchar4 __convert__((kernel)) invert(uchar4 in, uint32_t x, uint32_t y) { uchar4 out = in; out.r = 255 - in.r; out.g = 255 - in.g; return out; }
renderscript apis
if you want to use renderscript in your api, you can do it in following two ways −
sr.no | apis & description |
---|---|
1 |
android.renderscript this api is available on devices running android 3.0 and higher. |
2 |
android.support.v8.renderscript this api is available on devices running android 2.2 and higher. |
to android support library following tools are required −
- latest android sdk tools version
- latest android sdk build-tools version
how to use renderscript support library
first open the project.properties file in your project and add following lines in the file −
renderscript.target=18 renderscript.support.mode=true sdk.buildtools=18.1.0
now open your main class which use renderscript and add an import for the support library classes as following −
import android.support.v8.renderscript.*;
following are the purposes of above mentioned properties that we add in the project.properties file.
sr.no | project properties & description |
---|---|
1 |
renderscript.target it specifies the byte code version to be generated. |
2 |
renderscript.support.mode it specifies a compatible version for the generated byte code to fall back. |
3 |
sdk.buildtools it specifies the versions of android sdk build tools to use. |
now call your renderscript kernel functions and compute complex algorithms in your app.