Back

CreateGLView

JS Py
Hello World

GLView is a fast 2D canvas suitable for drawing and moving graphics around on the screen quickly, ideal for games. The options parameter should be always set to “Fast2d”.

glv = app.CreateGLView( width, height, options ) → app object: GLView

Use the CreateImage method of the GLView object to create an image that can be used with the GLView.
You can specity a callback function too which will be called once the image is ready to use.

To draw the sprite on the canvas use the DrawImage method.
Note: don't forget to specify all parameters, including angle. Otherwise the image will not be drawn.
You can leave either width or height -1 to scale the other parameter according to the sprite aspect ratio.

Once all drawing has been done, the Render method must be called to render all the GLView graphics to the screen.

Example - DrawImage

function OnStart()
{
    lay = app.CreateLayout( "Linear", "FillXY" );

    glview = app.CreateGLView( 1, 1, "Fast2d" );
    lay.AddChild( glview );

    img = glview.CreateImage( "/Sys/Img/Hello.png", DrawFrame );


    app.AddLayout( lay );
}

function DrawFrame()
{
    glview.DrawImage( img, 0.25, 0.3, 0.5, -1, 45 );
    glview.Render();
}
from native import app

def OnStart():
    global glview, img
    lay = app.CreateLayout( "Linear", "FillXY" )

    glview = app.CreateGLView(1, 1, "Fast2d")
    lay.AddChild(glview)

    img = glview.CreateImage( "/Sys/Img/Hello.png", DrawFrame )

    app.AddLayout(lay)

def DrawFrame():
    glview.DrawImage( img, 0.25, 0.3, 0.5, -1, 45 )
    glview.Render()
    Copy     Copy All       Run      

Render Loop

To create a rendering loop for a game, use the setInterval JavaScript function to call your drawing function at regular intervals.
The example below draws a continuously rotating image by calling the DrawFrame function 30 times each second, updating the angle each time:

Example - Render Loop

var angle = 0;

function OnStart()
{
    lay = app.CreateLayout( "Linear", "FillXY" );

    glview = app.CreateGLView( 1, 1, "Fast2d" );
    lay.AddChild( glview );

    img = glview.CreateImage( "/Sys/Img/Hello.png", StartRendering );


    app.AddLayout( lay );
}

function StartRendering()
{
    setInterval( DrawFrame, 1000/30 );
}

function DrawFrame()
{
    glview.DrawImage( img, 0.25, 0.3, 0.5, -1, angle );

    angle = angle + 10;
    if( angle == 360 ) angle = 0;

    glview.Render();
}
from native import app

angle = 0

def OnStart():
    global glview, img
    lay = app.CreateLayout( "Linear", "FillXY" )

    glview = app.CreateGLView(1, 1, "Fast2d")
    lay.AddChild(glview)

    img = glview.CreateImage("/Sys/Img/Hello.png", StartRendering)

    app.AddLayout(lay)

def StartRendering():
    app.SetInterval(DrawFrame, 1000/30 )

def DrawFrame():
    glview.DrawImage( img, 0.25, 0.3, 0.5, -1, angle )

    angle = angle + 10
    if( angle == 360 ) angle = 0

    glview.Render()
    Copy     Copy All       Run      

Sprite Touch Detection

If you need to want to simulate OnTouch for a GLView Image, you will need to keep track of the position, width and height that it has been drawn with. Then use the GLView OnTouch event to determine if the touch coordinates are within the GLView Image yourself. To prevent touch detect on all sprites on the touch position define a drawing order according to a list.

Example - Sprite Touch

objects = [];

//Called when application is started.
function OnStart() {
    //Create layout
    lay = app.CreateLayout( "linear" );

    //Create GLView
    glv = app.CreateGLView( 1, 1, "Fast2d" );
    glv.SetOnTouchUp( touch );

    //set first image
    img1 = glv.CreateImage( "/Sys/Img/Hello.png" );
    img1.name = "img1";
    img1.X = 0.1; img1.Y = 0.3;
    img1.W = 0.7; img1.H = 0.4;
    objects.push(img1);

    //set second image
    img2 = glv.CreateImage( "/Sys/Img/Droid1.png", startRender );
    img2.name = "img2";
    img2.X = 0.5; img2.Y = 0.5;
    img2.W = 0.5; img2.H = 0.3;
    objects.push(img2);

    lay.AddChild( glv );

    //Add layout to app.
    app.AddLayout( lay );
}

// Draw images
function startRender() {
    for(var i in objects) draw(objects[i]);
    glv.Render();
}

// Check which image was touched
function touch(ev) {
    for(var i = objects.length; i-- > 0; ) {
        if( touched( objects[i], ev ) ) {
            app.ShowPopup( "touched " + objects[i].name );
            break;
        }
    }
}

function draw(img, ev) {
    glv.DrawImage( img, img.X, img.Y, img.W, img.H, 0);
}

function touched(img, ev) {
    return img.X < ev.X && img.X + img.W > ev.X
        && img.Y < ev.Y && img.Y + img.H > ev.Y;
}
from native import app

objects = []

def OnStart():
    global glv, name, X, Y, W, H
    lay = app.CreateLayout( "linear" )

    glv = app.CreateGLView( 1, 1, "Fast2d" )
    glv.SetOnTouchUp( touch )

    img1 = glv.CreateImage( "/Sys/Img/Hello.png" )
    img1.name = "img1"
    img1.X = 0.1; img1.Y = 0.3
    img1.W = 0.7; img1.H = 0.4
    objects.append(img1)

    img2 = glv.CreateImage( "/Sys/Img/Droid1.png", startRender )
    img2.name = "img2"
    img2.X = 0.5; img2.Y = 0.5
    img2.W = 0.5; img2.H = 0.3
    objects.append(img2)

    lay.AddChild( glv )

    app.AddLayout( lay )

def startRender():
    for obj in objects:
        draw(obj)
    glv.Render()

def touch(ev):
    for obj in objects:
        if touched(obj, ev):
            app.ShowPopup( "touched " + obj.name )
            break

def draw(obj):
    glv.DrawImage( obj, obj.X, obj.Y, obj.W, obj.H, 0 )

def touched(obj, ev):
    return obj.X < ev.X and obj.X + obj.W > ev.X         and obj.Y < ev.Y and obj.Y + obj.H > ev.Y
Copy All       Run      

Sprite Animations

GLView supports the use of Sprite Sheets. The DrawSprite method can be used to draw part of an image to the GLView.
The following example uses a sprite sheet containing 8 stages of a character running. The DrawSprite method is used to draw each of the 8 sections in turn to give the effect of the character continuously running:

Example - Sprite Sheet Animation

var spriteCount = 8;
var srcWidth = 50;
var srcHeight = 60;
var frameCount = 0;

function OnStart()
{
    lay = app.CreateLayout( "Linear", "FillXY" );

    glview = app.CreateGLView( 1, 1, "Fast2d" );
    lay.AddChild( glview );

    img = glview.CreateImage( "/Sys/Img/Sprint.png", StartRendering );


    app.AddLayout( lay );
}

function StartRendering()
{
    setInterval(DrawFrame, 1000/30);
}

function DrawFrame()
{
    var spriteIndex = Math.floor(frameCount / 2) % spriteCount;

    var sx = spriteIndex * srcWidth;
    var sy = 0;

    glview.DrawSprite( img, sx, sy, srcWidth, srcHeight,
                0.3, 0.4, 0.3, -1 );

    glview.Render();
    frameCount++;
}
from native import app

spriteCount = 8
srcWidth = 50
srcHeight = 60
frameCount = 0

def OnStart():
    global glview, img
    lay = app.CreateLayout( "Linear", "FillXY" )

    glview = app.CreateGLView(1, 1, "Fast2d")
    lay.AddChild(glview)

    img = glview.CreateImage( "/Sys/Img/Sprint.png", StartRendering )

    app.AddLayout(lay)

def StartRendering():
    app.SetInterval( DrawFrame, 1000/30 )

def DrawFrame():
    spriteIndex = app.MathFloor(frameCount / 2) % spriteCount

    sx = spriteIndex * srcWidth
    sy = 0

    glview.DrawSprite( img, sx, sy, srcWidth, srcHeight,
                0.3, 0.4, 0.3, -1 )

    glview.Render()
    frameCount += 1
    Copy     Copy All       Run      

Methods

The following methods are available on the GLView object:

aspectNumber: float
canvasObject
CreateImage( file, callback ) → Object: img
      CreateImage.img.heightNumber: integer
      CreateImage.img.widthNumber: integer
DrawImage( image, x, y, w, h, angle )
DrawSprite( sheet, sx, sy, sw, sh, dx, dy, dw, dh, angle )
Focus()
GetAbsHeight() → Number: integer
GetAbsWidth() → Number: integer
GetContext() → Object: ctx
       GetContext.ctx.drawImage( image, sx, sy, sw, sh, dx, dy, dw, dh )
       GetContext.ctx.render()
       GetContext.ctx.restore()
       GetContext.ctx.rotate( angle )
       GetContext.ctx.save()
       GetContext.ctx.scale( a, d )
       GetContext.ctx.setTransform( a, b, c, d, tx, ty )
       GetContext.ctx.transform( a, b, c, d, tx, ty )
       GetContext.ctx.translate( tx, ty )
GetHeight( options ) → Number
GetLeft( options ) → Number
GetParent() → app object
GetPosition( options ) → Object: { left, top, width, height }
GetTop( options ) → Number
GetType() → String: “GLView”
GetVisibility() → String: “Show” or “Hide” or “Gone”
GetWidth( options ) → Number
Gone()
heightNumber: integer
Hide()
IsEnabled() → Boolean
IsOverlap( obj, depth ) → Boolean
IsVisible() → Boolean
Method( name, types, p1, p2, p3, p4 ) → all types
Render()
SetScale( x, y )
Show()
widthNumber: integer
Boolean
app object
Function
Number
String
unknown
Number: angle in degrees (0..360)
Number: factor
Number: fraction (0..1)
Number: integer
Number: milliseconds
Number: pixel
Number: angle in radient (0..2*π)
String:
  hexadecimal: “#rrggbb”, “#aarrggbb”
  colourName: “red”, “green”, ...
String: comma “,” separated
String: path to file ( “/absolute/...” or “relative/...” )
String: “fast2d”
String: path relative to “/sdcard”
String: “px”
String: “screen”, “px”
String: “left-right” or “right-left” or “top-bottom” or “bottom-top” or “bl-tr” or “br-tl” or “tl-br” or “tr-bl”
String: “repeat”
String: “px” or “sp” or “dip” or “mm” or “pt”
String: “px” or “sp” or “dip” or “dp” or “mm” or “pt”
String: “Show” or “Hide” or “Gone”
String: “Linear.None” or “Quadratic.In/Out” or “Cubic.In/Out” or “Quartic.In/Out” or “Quintic.In/Out” or “Sinusoidal.In/Out” or “Exponential.In/Out” or “Circular.In/Out” or “Elastic.In/Out” or “Back.In/Out” or “Bounce.In/Out”
Object: { COMMAND }
Object: img
Object: { source, action, count, x: [ x1, x2, x3 ], y: [ y1, y2, y3 ] }
Object: { source, action, count, x: [ x1, x2, x3 ], y: [ y1, y2, y3 ] }
Object: { source, action, count, x: [ x1, x2, x3 ], y: [ y1, y2, y3 ] }
Object: { source, action, count, x: [ x1, x2, x3 ], y: [ y1, y2, y3 ] }
Object: { x, y, w, h, sw, sh, rot }
List: boolean,char,byte,short,int,long,float,double,String,CharSequence,...
function()
function( event )
function( event )
function( event )
function( event )
width/height relation
glv.Batch
Batch method calls to be able to set all object's properties at once.
Note that you need to specify each parameter (use “” or null to leave some out)
Inherited methods can be called by appending an underscore to the function name (ie. txt.Batch({ SetBackColor_: [“red”] })
[HTMLDivElement]
glv.ClearFocus
Removes the focus of the control so that the user no longer has immediate access to it.
glv.CreateImage
Create a sprite object which can be drawn on the GLView
Height of the image
Width of the image
glv.DrawImage
Draws an image to the canvas
glv.DrawSprite
Draws a part of an image to the canvas.
glv.Focus
Set the focus to the control so that the user can interact with it immediately.
glv.GetAbsHeight
Get the absolute height of the control in pixels.
Note that unlike the objects margins its padding does change this value.
glv.GetAbsWidth
Get the absolute width of the control in pixels.
Note that unlike the objects margins its padding does change this value.
glv.GetContext
Returns the current FastCanvas context
glv.GetContext.ctx.capture
Captures the current cached context to a png image.
The path is relative to /sdcard but requires a leading '/', ie “/Pictures/mycapture.png”
glv.GetContext.ctx.clearRect
Note: This function is deprecated. does nothing. ctx is automatically cleared after render()
glv.GetContext.ctx.drawImage
Draws a part of a glv image to the glv context, where s are source coordinates and d destination coordinates.
glv.GetContext.ctx.render
render the draw commands to the context
glv.GetContext.ctx.resetTransform
Reset all transformations to default
glv.GetContext.ctx.restore
Restore a previously saved context state
glv.GetContext.ctx.rotate
Rotates the current applied transformation
glv.GetContext.ctx.save
Saves the current context state
glv.GetContext.ctx.scale
Scales the current applied transformation matrix
glv.GetContext.ctx.setTransform
Set the current transformation matrix
glv.GetContext.ctx.transform
Apply an other transformation matrix to the current one
glv.GetContext.ctx.translate
'Moves' the current applied transformation matrix
glv.GetHeight
Get the height of the control as screen height relative float or in pixels with the px option.
Note that unlike the objects margins its padding does change this value.
glv.GetLeft
Get the distance from the control to the left parent border as width relative float or in pixels with the px option.
glv.GetParent
Returns the parent control object where the object was added to - commonly a layout.
glv.GetPosition
Returns data about the position and size of the control.
If the screen option is given the position on the screen will be returned. Otherwise relative to the parent control.
The px options turns the relative values into pixels.
glv.GetTop
Get the distance from the control to the upper parent border as height relative float or in pixels with the px option.
glv.GetType
Returns the control class name.
glv.GetVisibility
Returns the current visibility state of the control. The Values are:
Show: visible
Hide: invisible but still consuming space
Gone: invisible and not consuming space
glv.GetWidth
Get the width of the control as screen width relative float or in pixels with the px option.
Note that unlike the objects margins its padding does change this value.
glv.Gone
Hides the control without consuming any more layout space as if it were never there.
height
glv.Hide
Hide the control but keep the layout space free.
glv.IsEnabled
Returns whether the control is currently useable by the user.
glv.IsOverlap
Returns whether the control overlaps with another by a given distance.
glv.IsVisible
Returns whether the control is currently visible to the user, ignoring overlaying controls.
glv.Method
Allows access to other functions defined on the object in Java via reflection.

Note: This function is a premium feature. Please consider subscribing to Premium to use this feature and support DroidScript in its further development.
glv.Render
Render all draw commands to the canvas
glv.SetBackColor
Changes the background color of the control.
glv.SetBackGradient
Define the background color of the control with a gradient. The default gradient direction is from top to bottom, but you can change it from left to right and the reversed versions of course.
glv.SetBackGradientRadial
Define a radial color gradient for the background of control.
glv.SetBackground
Changes the background to an image which can be repeated using the repeat option.
An image which is often used with that option is '/res/drawable/pattern_carbon' - try it out!
glv.SetDescription
Set a control description for accessibility
glv.SetEnabled
En/Disable the control physically and visually so that the user can/can not access the control. Events like OnTouch will still be fired.
glv.SetMargins
Define a distance to other controls on each side of the control.
glv.SetOnTouch
Define a callback function that is called when the user touches the control. In addition, an event object is passed to the callback function to obtain information about the touch type, the touch position(s), the amount of touches and the control that was touched.
glv.SetOnTouchDown
Define a callback function which is called when the user started toching the control.
glv.SetOnTouchMove
Define a callback function which is called when the user drags a finger over the screen.
glv.SetOnTouchUp
Define a callback function which is called when the users finger leaves the screen.
glv.SetPadding
Define distances that elements within the control are to maintain from the control borders.
glv.SetPosition
Defines the position and size for the control if the parent is an absolute layout.
glv.SetScale
Scales the control along with its contents by the factors passed to the function.
glv.SetSize
Change the size of the control in either screen relative values or in pixels if the px option was given.
glv.SetTouchable
En/Disables touch events to be fired on the control. Other events like OnChange will still be fired.
glv.SetVisibility
Change the visibility of the control to one of the available modes:
Show: visible
Hide: invisible but still consuming space
Gone: invisible and not consuming space
glv.Show
Set the visibility of the control to “Show”.
glv.Tween
Performs an animation on the control.
The target object is for the position, size and rotation that the control has at the end of the animation.

The type specifies the behavior and the speed of the animation. Separated by a dot, you must also specify whether you want to apply this behavior to the beginning (In), end (Out), or to both (InOut) times of the animation.

With the amount of repeats you can control how many times you want to play the animation.

If you have jojo activated, the animation will alternate between forward and backward playback, so that if the repetition value is odd, the control will be at the start position again at the end of the animation.

Finally the callback function will be called after the animation has finished. Well, it's about time!
width