Enable and disable the whiteboard
The whiteboard module in Flexible Classroom is implemented based on AgoraWidget
. You can turn the whiteboard module on or off in the classroom by setting the widget state as active or inactive.
After disabling the whiteboard module, drawing tools including pencil, text box, shape, and eraser will no longer be available and users cannot upload, delete, or display class files on the whiteboard. Other features that do not rely on the whiteboard, such as uploading or deleting class files, pop-up quiz, count-down timer, and screen sharing will not be affected.
Turn the whiteboard on or off
The component corresponding to the Whiteboard widget is named AgoraEduWhiteBoardComponent
, and the widget ID can be obtained using AgoraWidgetDefaultId.WhiteBoard.id
. Use this component to turn the Whiteboard on or off.
To enable or disable the Whiteboard, you monitor the status changes of the Whiteboard caused by the teacher client and adjust the UI accordingly. See initView()
in the file AgoraEduUIKit/src/main/java/com/agora/edu/component/whiteboard/AgoraEduWhiteBoardComponent.kt
for the logic of registering observers, listening for active states, and creating or destroying Whiteboard components in the methods.
If you want to open and close the Whiteboard by yourself, you can refer to the following code examples:
-
To turn on the Whiteboard, add the following code to the file where the button to open the Whiteboard is located:
-
To close the Whiteboard, add the following code to the file where the button to close the Whiteboard is located:
-
To register an observer, use the following code:
-
To monitor the status of the widget, use the following code:
API Reference
AgoraWidgetContext
create
Create a Widget object instance.
Parameter:
- config: The configuration information of this Widget object.
Return: Widget instance, empty means creation failed.
getWidgetConfig
Get the configuration information of a registered Widget.
Parameter:
- widgetId: The unique identifier of the Widget.
Return: An AgoraWidgetConfig
object.
setWidgetActive
Activate a Widget.
Parameter:
- widgetId: Widget's unique identifier.
- ownerUserUuid: UserUuid of the user who owns the currently activated Widget.
- roomProperties: Initialized room properties.
- callback: Callback listener for activation operation.
Return: After the operation is successful, you will receive the callback of AgoraWidgetActiveObserver.onWidgetActive
setWidgetInActive
Unregister the specified Widget.
Parameter:
- widgetId: Widget's unique identifier.
- isRemove: Whether to completely delete all information of this Widget in the current classroom:
- true: Delete completely. All information under
roomProperties.widgets.'widgetId'
anduserProperties.widgets.'widgetId'
will be removed. - false: Only set
roomProperties.widgets.'widgetId'.state
to '0', that is, set the current Widget as inactive. No matter what this value is passed, it will receive the callback ofAgoraWidgetActiveObserver.onWidgetInActive
.
- true: Delete completely. All information under
- callback: Callback listener for logout operation.
getWidgetActive
Get the activation state of a Widget.
Parameter:
- widgetId: Widget's unique identifier.
Return: Boolean indicating the activation state of a Widget.
getAllWidgetActive
Get the activation status of all registered Widgets.
Return: Map holding the activation statuses of all registered Widgets.
addWidgetActiveObserver
Add an AgoraWidgetActiveObserver
listener to monitor whether this Widget is active.
Parameter:
- observer:
AgoraWidgetActiveObserver
listener to add. - widgetId: Widget's unique identifier.
removeWidgetActiveObserver
Delete an AgoraWidgetActiveObserver
listener.
Parameter:
- observer:
AgoraWidgetActiveObserver
listener to remove. - widgetId: Widget's unique identifier.
addWidgetMessageObserver
Add an AgoraWidgetMessageObserver
listener to listen to all messages sent by this Widget.
Parameter:
- observer:
AgoraWidgetMessageObserver
listener to add. - widgetId: Widget's unique identifier.
removeWidgetMessageObserver
Delete an AgoraWidgetMessageObserver
listener.
Parameter:
- observer:
AgoraWidgetMessageObserver
listener to remove. - widgetId: Widget's unique identifier.
sendMessageToWidget
Send a message to a Widget.
Parameter:
- msg: Message to send.
- widgetId: Widget's unique identifier.