Layouts are container objects which are used to visually organize graphical objects (controls), such as text, buttons and images on the screen.
lay = app.CreateLayout(
type,
options )
→
app object: Layout
There are 4 types of layouts: “Linear”, “Absolute”, “Frame” and “Card”.
Layouts are transparent by default but you can set a background image which can be tiled or stretched to fill the layout. You can also set a background color or background gradient.
You can add child objects to the Layout using the AddChild function: lay.AddChild( object );
The alignment of chlld objects within a layout can be set by adding the options “Left”, “Right”, “Bottom” and “VCenter”, by default objects will be aligned “Top,Center”.
Linear Layouts
Linear layouts are probably the most useful type and are used to organize controls in either the default “Vertical” or “Horizontal” direction on screen.
Example - Vertical
function OnStart()
{
lay = app.CreateLayout( "Linear", "Vertical" );
btnA = app.CreateButton( "A", 0.2, 0.1 );
lay.AddChild( btnA );
btnB = app.CreateButton( "B", 0.2, 0.1 );
lay.AddChild( btnB );
btnC = app.CreateButton( "C", 0.2, 0.1 );
lay.AddChild( btnC );
app.AddLayout( lay );
}
from native import app
def OnStart():
lay = app.CreateLayout( "Linear", "Vertical" )
btnA = app.CreateButton( "A", 0.2, 0.1 )
lay.AddChild( btnA )
btnB = app.CreateButton( "B", 0.2, 0.1 )
lay.AddChild( btnB )
btnC = app.CreateButton( "C", 0.2, 0.1 )
lay.AddChild( btnC )
app.AddLayout( lay )
Example - Horizontal
function OnStart()
{
lay = app.CreateLayout( "Linear", "Horizontal,FillXY" );
btnA = app.CreateButton( "A", 0.2, 0.1 );
lay.AddChild( btnA );
btnB = app.CreateButton( "B", 0.2, 0.1 );
lay.AddChild( btnB );
btnC = app.CreateButton( "C", 0.2, 0.1 );
lay.AddChild( btnC );
app.AddLayout( lay );
}
from native import app
def OnStart():
lay = app.CreateLayout( "Linear", "Horizontal,FillXY" )
btnA = app.CreateButton( "A", 0.2, 0.1 )
lay.AddChild( btnA )
btnB = app.CreateButton( "B", 0.2, 0.1 )
lay.AddChild( btnB )
btnC = app.CreateButton( "C", 0.2, 0.1 )
lay.AddChild( btnC )
app.AddLayout( lay )
By default Layouts will auto-size to wrap their contents but you have 3 more options as to how a layout sizes within it's parent: “FillX”, “FillY” and “FillXY”.
Example - Combined
function OnStart()
{
layVert = app.CreateLayout( "Linear", "Vertical,FillXY" );
btnA = app.CreateButton( "A", 0.6, 0.1 );
layVert.AddChild( btnA );
layHoriz = app.CreateLayout( "Linear", "Horizontal" );
layVert.AddChild( layHoriz );
btnB1 = app.CreateButton( "B1", 0.2, 0.1 );
layHoriz.AddChild( btnB1 );
btnB2 = app.CreateButton( "B2", 0.2, 0.1 );
layHoriz.AddChild( btnB2 );
btnB3 = app.CreateButton( "B3", 0.2, 0.1 );
layHoriz.AddChild( btnB3 );
btnC = app.CreateButton( "C", 0.6, 0.1 );
layVert.AddChild( btnC );
app.AddLayout( layVert );
}
from native import app
def OnStart():
layVert = app.CreateLayout( "Linear", "Vertical,FillXY" )
btnA = app.CreateButton( "A", 0.6, 0.1 )
layVert.AddChild( btnA )
layHoriz = app.CreateLayout( "Linear", "Horizontal" )
layVert.AddChild( layHoriz )
btnB1 = app.CreateButton( "B1", 0.2, 0.1 )
layHoriz.AddChild( btnB1 )
btnB2 = app.CreateButton( "B2", 0.2, 0.1 )
layHoriz.AddChild( btnB2 )
btnB3 = app.CreateButton( "B3", 0.2, 0.1 )
layHoriz.AddChild( btnB3 )
btnC = app.CreateButton( "C", 0.6, 0.1 )
layVert.AddChild( btnC )
app.AddLayout( layVert )
Frame Layouts
Frame layouts are used to display objects in front or behind each other. Every time the AddChild function is called on a Frame layout, the child object is placed in a new layer in front of the previously added object at the top left of the frame.
Frame Layouts are useful if you wish to do animated Flips or Slides to reveal layers of objects or use transparency.
Example - Image Swap
function OnStart()
{
lay = app.CreateLayout( "Linear", "VCenter,FillXY" );
layFrm = app.CreateLayout( "Frame" );
img1 = app.CreateImage( "/Sys/Img/Droid1.png", 0.5 );
layFrm.AddChild( img1 );
img2 = app.CreateImage( "/Sys/Img/Hello.png", 0.5 );
img2.SetVisibility( "Hide" );
layFrm.AddChild( img2 );
lay.AddChild( layFrm );
btn = app.CreateButton( "Press Me" );
btn.SetMargins( 0,0.1,0,0 );
btn.SetOnTouch( btn_OnTouch );
lay.AddChild( btn );
app.AddLayout( lay );
}
function btn_OnTouch()
{
if( img2.GetVisibility() == "Hide" )
img2.SetVisibility( "Show" );
else
img2.SetVisibility( "Hide" );
}
from native import app
def OnStart():
global img2
lay = app.CreateLayout( "Linear", "VCenter,FillXY" )
layFrm = app.CreateLayout( "Frame" )
img1 = app.CreateImage( "/Sys/Img/Droid1.png", 0.5 )
layFrm.AddChild( img1 )
img2 = app.CreateImage( "/Sys/Img/Hello.png", 0.5 )
img2.SetVisibility( "Hide" )
layFrm.AddChild( img2 )
lay.AddChild( layFrm )
btn = app.CreateButton( "Press Me" )
btn.SetMargins( 0,0.1,0,0 )
btn.SetOnTouch( btn_OnTouch )
lay.AddChild( btn )
app.AddLayout( lay )
def btn_OnTouch():
if img2.GetVisibility() == "Hide":
img2.SetVisibility( "Show" )
else:
img2.SetVisibility( "Hide" )
Absolute Layouts
Absolute layouts ignore all alignment options and allow the absolute positioning of controls by calling the SetPosition and SetSize functions of each of the child objects. However, you are encouraged use linear layouts for most of your programs, unless it is absolutely necessary.
Card Layouts
Card Layouts are just like frame layouts, but with rounded corners and a shadow by default.
They may be used to display offers with an image and optional info text.
Methods
The following methods are available on the Layout object:
Boolean
app object
Number
String
unknown
Number: factor
Number: fraction (0..1)
Number: integer
Number: milliseconds
Number: pixel
Number: -180..180
Number: -100..100
Number: 0..100
Number: 0..0.99 or 1..256
String:
hexadecimal: “#rrggbb”, “#aarrggbb”
colourName: “red”, “green”, ...
String: comma “,” separated
String: path to file ( “/absolute/...” or “relative/...” )
String: “Linear” or “Absolute” or “Frame” or “Card”
String: comma “,” separated: “AutoSize”,
“TouchThrough”,
“TouchSpy”,
“Left” or
“Top” or
“Right” or
“Bottom” or
“Center” or
“H/VCenter”,
“Wrap”,
“Horizontal” or
“Vertical”,
“FillX/Y”
String: “NewsPaper” or
“Jelly” or
“Flash” or
“RubberBand” or
“Swing” or
“TaDa” or
“Bounce” or
“Fall” or
“FallRotate” or
“
”
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
“dip” or
“sp” or
“mm” or
“pt” or
“pl” or
“ps”
String: “Add” or “Multiply” or “clear” or “darken” or “lighten” or “overlay” or “screen” or “xor” or “color” or “color_burn” or “color_dodge” or “difference” or “exclusion” or “hard_light” or “hue” or “luminosity” or “modulate” or “saturation” or “soft_light” or “src” or “dst” or “src_in” or “src_out” or “src_atop” or “src_over” or “dst_in” or “dst_out” or “dst_atop” or “dst_over”
String: “Left”, “Top”, “Right”, “Bottom”, “VCenter”, “HCenter”, “FillX”, “FillY”, “FillXY”
String: “Horizontal” or “Vertical”
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: {
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()
lay.AddChild
Adds a control to the layout.
lay.AdjustColor
Adjust the visual color effect of the control by setting the Hue (by angle in degrees in a color circle), the saturation, brightness and contrast of the control.
lay.Animate
Animates the control.
There are
“in”-Animations which are used to show objects from hidden state
“out”-animations which are used to hide objects in visible state and
“static”-animations which keep the visible state.
lay.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”] })
lay.ChildToFront
Moves a child in front of all other children.
lay.ClearFocus
Removes the focus of the control so that the user no longer has immediate access to it.
lay.DestroyChild
Destroys and removes a child from the layout.
lay.Focus
Set the focus to the control so that the user can interact with it immediately.
lay.GetAbsHeight
Get the absolute height of the control in pixels.
Note that unlike the objects margins its padding does change this value.
lay.GetAbsWidth
Get the absolute width of the control in pixels.
Note that unlike the objects margins its padding does change this value.
lay.GetChildOrder
Returns the z order of a child.
lay.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.
lay.GetLeft
Get the distance from the control to the left parent border as width relative float or in pixels with the px option.
lay.GetParent
Returns the parent control object where the object was added to - commonly a layout.
lay.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.
lay.GetTop
Get the distance from the control to the upper parent border as height relative float or in pixels with the px option.
lay.GetType
Returns the control class name.
lay.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
lay.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.
lay.Gone
Hides the control without consuming any more layout space as if it were never there.
lay.Hide
Hide the control but keep the layout space free.
lay.IsEnabled
Returns whether the control is currently useable by the user.
lay.IsOverlap
Returns whether the control overlaps with another by a given distance.
lay.IsVisible
Returns whether the control is currently visible to the user, ignoring overlaying controls.
lay.MethodAllows 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.
lay.RemoveChild
Removes a child from the layout.
lay.Resize
Resize a control after device rotation by keeping the original width/height ratios.
lay.SetBackAlpha
Set the transparency of the background by an alpha value between 0 (no transparency) and 0.99 (full transparent) or 1 (no transparency) and 256 (full transparent)
lay.SetBackColor
Changes the background color of the control.
lay.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.
lay.SetBackGradientRadial
Define a radial color gradient for the background of control.
lay.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!
lay.SetChildMargins
Set margins of top-level children.
lay.SetChildTextSize
Change the text size of top-level children.
lay.SetColorFilterAdjust the visual color effect with a color and a given BlendMode. More information about BlendMode can be found in the
Android Developer page.
lay.SetCornerRadius
Applies a corner radius to card layouts.
lay.SetDescription
Set a control description for accessibility
lay.SetElevation
Applies a shadow to card layouts.
lay.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.
lay.SetGravity
Adjust the placing of contained children.
lay.SetMargins
Define a distance to other controls on each side of the control.
lay.SetOnChildChange
Defines a callback function which is called when the content of a child control has been changed by the user.
lay.SetOnLongTouch
Define a callback function which is called when the object has been long pressed.
lay.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.
lay.SetOnTouchDown
Define a callback function which is called when the user started toching the control.
lay.SetOnTouchMove
Define a callback function which is called when the user drags a finger over the screen.
lay.SetOnTouchUp
Define a callback function which is called when the users finger leaves the screen.
lay.SetOrientation
Change the children orientation.
lay.SetPadding
Define distances that elements within the control are to maintain from the control borders.
lay.SetPosition
Defines the position and size for the control if the parent is an absolute layout.
lay.SetScale
Scales the control along with its contents by the factors passed to the function.
lay.SetSize
Change the size of the control in either screen relative values or in pixels if the px option was given.
lay.SetTouchable
En/Disables touch events to be fired on the control. Other events like OnChange will still be fired.
lay.SetTouchThrough
Define whether the layout should forward OnTouch events to underlying controls.
lay.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
lay.Show
Set the visibility of the control to “Show”.
lay.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!