在线教育平台开发中,教学白板是如何实现的

简介: 教学白板是在线教育平台中不可缺少的功能,它的作用就如线下教室的黑板,讲师通过它进行板书、课件展示等操作。下面小编以iOS版本的在线教育平台开发为例,来说明白板功能是如何实现和调用的。

教学白板是在线教育平台中不可缺少的功能,它的作用就如线下教室的黑板,讲师通过它进行板书、课件展示等操作。下面小编以iOS版本的在线教育平台开发为例,来说明白板功能是如何实现和调用的。
online_4702486_960_720

1、向服务器获取对应 room uuid 所需要的房间 roomToken,实际使用中,这步可以放在服务端。

{
    [WhiteUtils getRoomTokenWithUuid:self.roomUuid completionHandler:^(NSString * _Nullable roomToken, NSError * _Nullable error) {
        if (roomToken) {
            self.roomToken = roomToken;
//获取到token之后加入房间
             [self joinRoomWithToken:roomToken];
         } else {
            UIAlertController *alertVC = [UIAlertController alertControllerWithTitle:NSLocalizedString(@"获取 RoomToken 失败", nil) message:[NSString stringWithFormat:@"错误信息:%@", [error description]] preferredStyle:UIAlertControllerStyleAlert];
            UIAlertAction *action = [UIAlertAction actionWithTitle:NSLocalizedString(@"确定", nil) style:UIAlertActionStyleCancel handler:^(UIAlertAction * _Nonnull action) {
                [self.navigationController popViewControllerAnimated:YES];
            }];
            [alertVC addAction:action];
            [self presentViewController:alertVC animated:YES completion:nil];
        }
    }];
}

2、加入白板房间

{
    //配置头像,可以在操作的白板的时候展示头像
    NSDictionary *payload = @{@"avatar": [Config getavatarThumb]};
    WhiteRoomConfig *roomConfig = [[WhiteRoomConfig alloc] initWithUuid:self.roomUuid roomToken:roomToken userPayload:payload];
    // * isWritable 默认为 yes,此处为了单元测试用
    roomConfig.isWritable = YES;
    // 配置,橡皮擦是否能删除图片。默认为 false,能够删除图片。
    // roomConfig.disableEraseImage = YES;

    [self.sdk joinRoomWithConfig:roomConfig callbacks:nil completionHandler:^(BOOL success, WhiteRoom * _Nonnull room, NSError * _Nonnull error) {
        if (success) {

            self.roomToken = roomToken;
            self.room = room;
            isDisableTeachingAids = YES;
//禁止用户的教具操作 ture为禁止
            [_room disableDeviceInputs:YES];

        } else {
            self.title = NSLocalizedString(@"加入失败", nil);
            UIAlertController *alertVC = [UIAlertController alertControllerWithTitle:NSLocalizedString(@"加入房间失败", nil) message:[NSString stringWithFormat:@"错误信息:%@", [error localizedDescription]] preferredStyle:UIAlertControllerStyleAlert];
            UIAlertAction *action = [UIAlertAction actionWithTitle:NSLocalizedString(@"确定", nil) style:UIAlertActionStyleCancel handler:^(UIAlertAction * _Nonnull action) {
                [self.navigationController popViewControllerAnimated:YES];
            }];
            [alertVC addAction:action];
            [self presentViewController:alertVC animated:YES completion:nil];
        }
    }];
}

3、教具的使用操作

/*
WhiteApplianceNameKey const AppliancePencil = @"pencil";
WhiteApplianceNameKey const ApplianceSelector = @"selector";
WhiteApplianceNameKey const ApplianceText = @"text";
WhiteApplianceNameKey const ApplianceEllipse = @"ellipse";
WhiteApplianceNameKey const ApplianceRectangle = @"rectangle";
WhiteApplianceNameKey const ApplianceEraser = @"eraser";
*/
        currentmState.currentApplianceName = AppliancePencil;
//颜色可以自定义
        currentmState.strokeColor = [UIColor redColor];
//画线宽度可以自定义
        currentmState.strokeWidth = 10;
        [self.room setMemberState:currentmState];

4、退出房间

以上就是iOS版本的在线教育平台开发过程中,教学白板的实现和调用过程。

声明:以上内容为作者本人原创,未经作者本人同意,禁止转载,否则将追究相关法律责任。

相关文章
|
2月前
|
人工智能 机器人 Serverless
云端问8期-实践教学
云端问8期-实践教学
|
6月前
|
算法
互动游戏解决遇到问题之开发同学是如何实现小鸡移动的
互动游戏解决遇到问题之开发同学是如何实现小鸡移动的
|
7月前
|
图形学 开发者
U3D小游戏开发实战:构建趣味互动体验的全面指南
【7月更文第13天】Unity 3D(U3D)作为业界领先的跨平台游戏开发引擎,以其强大的功能和灵活性,成为无数开发者打造创意小游戏的理想选择。本文将深入探讨如何利用U3D构建一款既有趣又互动的小游戏项目,从概念设计到实现细节,涵盖基础设置、核心逻辑编码、以及优化技巧,旨在为开发者提供一套实战性极强的开发流程指南。
322 0
|
JavaScript 前端开发 Java
如何快速开发功能含体育直播+竞猜+视频+社区+新闻+聊天平台?
通过东莞梦幻网络科技的现成“体育赛事直播”源码解决方案,功能涵盖体育直播、竞猜、视频、社区、新闻和聊天等多功能,该方案源码可让平台能快速于3天内上线运营。
|
前端开发 JavaScript Java
基于PHP开发的娱乐游戏直播应用系统开发案例
随着移动互联网的普及和高速发展,娱乐游戏直播应用成为当今社交娱乐的重要组成部分。下面给分享东莞梦幻网络科技“娱乐游戏直播应用系统”开发案例。
|
负载均衡 数据安全/隐私保护
一对一直播app开发,直播间的搭建重点
一对一直播app开发,直播间的搭建重点
元宇宙游戏开发上线版,元宇宙游戏系统开发技术详细案例及源码
 元宇宙的说法众说纷纭,技术、应用、资产、服务、产业、生态和哲学等不同层次的定义混杂,严重影响业界对元宇宙的认识。本体论是科技哲学的重要理论,是在科技发展初期解释科技发现的有效方法。通过本体论可以从不同视角调查、分析和研究事物的现象、范例及其相互关系,帮助提炼科技发现本质的定义、知识、要素及其内在逻辑结构,并用数学方式将知识固化形成科技范式,通过计算机相关技术和标准化方式呈现。元宇宙刚刚出现,需要用系统分析的方法明确外延、内涵和核心要素,从而统一产业共识,降低产业沟通成本,加速推动元宇宙产业支撑数字经济高质量发展。
|
人工智能 5G 区块链
元宇宙游戏项目系统开发技术功能版及源码方案
元宇宙游戏项目系统开发技术功能版及源码方案
191 0
|
存储 移动开发 小程序
家校协同小程序实战教程
家校协同小程序实战教程
家校协同小程序实战教程

热门文章

最新文章