Custom Spotlight Extension
Release Date: 2021-03-13T22:00:00Z
Last Update Date: 2021-03-14T22:00:00Z
Current Update: 1.1
Required Permissions: None ( it would require the READ_EXTERNAL_STORAGE
when reading a custom typeface from the external storage )
Used Libraries: A customized version from the Spotlight-3 by matrixxun and TakuSemba
Description
This extension creates a spotlight on visible components, or on a specific coordinate on the screen, with a different style than kodular’s built-in component. you can customize the title, description and mask properties or use your custom layout. This extension can be useful to create a tutorial when the user enters your app for the first time, to point out to the primary functions and their description.
Blocks Picture
Documentation
Ended
Called when a spotlight ends.
data:image/s3,"s3://crabby-images/544f3/544f3e4dd863c019755bf822537eb12f72fb9338" alt="component_event(1)"
Started
Called when a spotlight starts.
data:image/s3,"s3://crabby-images/888d2/888d2ac0b1dd5fca1bc1a7a9d0b570728e3a6b3c" alt="component_event(2)"
Type |
Name |
Description |
String |
id |
the spotlight's id |
Error
Called when an error occurs, if you don't handle this event, the error would be dispatched to app's UI.
data:image/s3,"s3://crabby-images/67ea6/67ea65bac5dc8a7d42cb2e7da22799578aebd797" alt="component_event(3)"
Type |
Name |
Description |
String |
error |
the full error message |
Target Closed
Called when a target is closed.
data:image/s3,"s3://crabby-images/03ac8/03ac8c8cffe0e47180ddc35e2cbd23d728d581b9" alt="component_event(4)"
Type |
Name |
Description |
String |
error |
the id of the target, uses the spotlight id when using one of the blocks that shows a single spotlight |
Dismiss Spotlight
Dismisses the whole currently shown spotlight.
data:image/s3,"s3://crabby-images/aa460/aa4605955264548679046a81a29483508562f95a" alt="component_method(11)"
Dismiss Target
Dismisses the currently shown target.
data:image/s3,"s3://crabby-images/6dd87/6dd87c08cf15b3382dc9c7370a00a275590a5b07" alt="component_method(10)"
Show Custom Spotlights
Shows a spotlight using a custom layout.
data:image/s3,"s3://crabby-images/3e32b/3e32bcc6a6fea024bc00d494ffbb217a9c4f849b" alt="component_method(2)"
Type |
Name |
Description |
Component |
component |
the component to show the spotlight on, can be any visible component, or a FloatingActionButton |
Number |
duration |
the duration that the spotlight show take to show or hide, in melliseconds |
Number |
radius |
the spotlight circle radius |
Componet |
spotlightLayout |
the layout used for the spotlight |
Number |
layoutY |
tthe y position of the layout, in pixels |
Number |
layoutX |
the X position of the layout, in pixels |
String |
id |
a unique id for the spotlight, used when calling the Started and Ended events |
Show Custom Spotlights At Point
Shows a spotlight at a specific coordinate using a custom layout.
data:image/s3,"s3://crabby-images/9abe9/9abe9799e67bf2793a7d5823059e0e00a75e0972" alt="component_method(3)"
Type |
Name |
Description |
Number |
x |
the x coordinate to show the spotlight at, in pixels |
Number |
y |
the y coordinate to show the spotlight at, in pixels |
Number |
duration |
the duration that the spotlight show take to show or hide, in melliseconds |
Number |
radius |
the spotlight circle radius |
Componet |
spotlightLayout |
the layout used for the spotlight |
Number |
layoutY |
the y position of the layout, in pixels |
Number |
layoutX |
the X position of the layout, in pixels |
String |
id |
a unique id for the spotlight, used when calling the Started and Ended events |
Show Multiple Custom Spotlights
Shows multiple spotlight using a custom layout.
data:image/s3,"s3://crabby-images/b06be/b06bedc3aa73c161ef35bb639b4eb59a3750b66d" alt="component_method(4)"
Type |
Name |
Description |
List |
components |
ta list of components to show the spotlights on |
Number |
duration |
the duration that the spotlight show take to show or hide, in melliseconds |
List |
radii |
a list of the spotlights' circle radii |
List |
spotlightLayouts |
a list of layouts used for the spotlight |
List |
layoutYPositions |
a list of the y positions of the layout, in pixels |
List |
layoutXPositions |
a list of the x positions of the layout, in pixels |
String |
id |
a unique id for the spotlight, used when calling the Started and Ended events |
List |
targetIds |
the ids of the targerts, used when calling TargetClosed event |
Show Multiple Custom Spotlights At Positions
Shows multiple spotlight using a custom layout at a specific coordinate.
data:image/s3,"s3://crabby-images/dd19d/dd19d7cd75e68bf8a940a9435cf00df735916d9d" alt="component_method(5)"
Type |
Name |
Description |
List |
xPositions |
a list of x coordinate to show the spotlight at, in pixels |
List |
yPositions |
a list of y coordinate to show the spotlight at, in pixels |
Number |
duration |
the duration that the spotlight show take to show or hide, in melliseconds |
List |
radii |
a list of the spotlights' circle radii |
List |
spotlightLayouts |
a list of layouts used for the spotlight |
List |
layoutYPositions |
a list of the y positions of the layout, in pixels |
List |
layoutXPositions |
a list of the x positions of the layout, in pixels |
String |
id |
a unique id for the spotlight, used when calling the Started and Ended events |
List |
targetIds |
the ids of the targerts, used when calling TargetClosed event |
Show Multiple Spotlights
Shows multiple spotlights on the components given.
data:image/s3,"s3://crabby-images/5406a/5406a661fed685f9fda65b20effdcf94e1d975df" alt="component_method(6)"
Type |
Name |
Description |
Component |
component |
the component to show the spotlight on, can be any visible component, or a FloatingActionButton |
List |
titles |
a list of the spotlights' titles, supports HTML text |
List |
descriptions |
a list of the spotlights' descriptions, supports HTML text |
Number |
duration |
the duration that the spotlight show take to show or hide, in melliseconds |
List |
radii |
the spotlight circle radius |
String |
id |
a unique id for the spotlight, used when calling the Started and Ended events |
List |
targetIds |
the ids of the targerts, used when calling TargetClosed event |
Show Multiple Spotlights At Positions
Shows multiple spotlights on a specific coordinates.
data:image/s3,"s3://crabby-images/40ba0/40ba07f815a6939bf71841819fcd16b5bfa5c9e2" alt="component_method(7)"
Type |
Name |
Description |
List |
xPositions |
ta list of x coordinate to show the spotlight at, in pixels |
List |
yPositions |
ta list of y coordinate to show the spotlight at, in pixels |
List |
titles |
a list of the spotlights' titles, supports HTML text |
List |
descriptions |
a list of the spotlights' descriptions, supports HTML text |
Number |
duration |
the duration that the spotlight show take to show or hide, in melliseconds |
List |
radii |
the spotlight circle radius |
String |
id |
a unique id for the spotlight, used when calling the Started and Ended events |
List |
targetIds |
the ids of the targerts, used when calling TargetClosed event |
Show Spotlight
Shows a spotlight on the given component.
data:image/s3,"s3://crabby-images/71cc9/71cc94d7cd656722ab2ad5596c55f9130fbad30a" alt="component_method(8)"
Type |
Name |
Description |
Component |
component |
the component to show the spotlight on, can be any visible component, or a FloatingActionButton |
String |
title |
the spotlight's titles, supports HTML text |
String |
description |
the spotlight's descriptions, supports HTML text |
Number |
duration |
the duration that the spotlight show take to show or hide, in melliseconds |
List |
radii |
the spotlight circle radius |
String |
id |
a unique id for the spotlight, used when calling the Started and Ended events |
Show Spotlight At Point
Shows a spotlight at a specific coordinate.
data:image/s3,"s3://crabby-images/4ba0f/4ba0f475c13377f47763b2a190769886d67d9a5a" alt="component_method(9)"
Type |
Name |
Description |
Number |
x |
the x coordinate to show the spotlight at, in pixels |
Number |
y |
the y coordinate to show the spotlight at, in pixels |
String |
title |
the spotlight's titles, supports HTML text |
String |
description |
the spotlight's descriptions, supports HTML text |
Number |
duration |
the duration that the spotlight show take to show or hide, in melliseconds |
List |
radii |
the spotlight circle radius |
String |
id |
a unique id for the spotlight, used when calling the Started and Ended events |
Designer Properties
data:image/s3,"s3://crabby-images/a65d3/a65d3121a18f2026c2b289bb9868ca7d166a1550" alt="image"
Usage Example
This is a very simple example blocks that demonstrates how to use this extension, you will find the AIA attached in the Downloads section
Screenshots And Screen Recordings
Downloads
Version 1.0
AIX: io.mohamed.CustomSpotlight.aix (61.0 KB)
AIA: spotlight_test.aia (218.6 KB)
APK: spotlight_test.apk (5.6 MB)
AIX: io.mohamed.CustomSpotlight.aix (62.0 KB)
AIA: spotlight_test(1).aia (219.5 KB)
APK: spotlight_test(1).apk (5.6 MB)
Change Logs
Version 1.1
New Blocks
1-
2-
Improvments
- Added helpUrl
- Removed the android support library. Since it’s no longer needed.
Bug Fixes
- Fixed a bug when using assets as a custom TypeFace in the companion, on android 10+ devices.
Open Source
This extension and the code of the customized library are open source:
Credits
Thanks for @themaayur for suggesting the extension’s idea, and for testing the extension.
Also thanks for the library authors, and for Kodular stuff for creating this awesome platform.
Thank You!