怎样在EgretNative中接入广告SDK?-创新互联

Egret Native可以通过原生扩展能力接入第三方原生SDK,本文将为开发者介绍如何接入广告系统。穿山甲是字节跳动提供的广告接入SDK,提供了多种广告样式,具体信息可以参见其官方文档。

站在用户的角度思考问题,与客户深入沟通,找到和硕网站设计与和硕网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:成都网站设计、成都网站制作、外贸网站建设、企业官网、英文网站、手机端网站、网站推广、申请域名、网页空间、企业邮箱。业务覆盖和硕地区。

穿山甲平台准备

进入穿山甲平台官网,完成注册登录,并按照平台要求完成应用和代码位的创建,具体操作可参照平台帮助中心的说明。

**Android

下载示例 Demo**

白鹭引擎已经为开发者提供了示例Demo,开发者可以直接基于该Demo 学习如何接入穿山甲广告SDK。demo项目包含一个egret工程,一个android工程,一个debug安装包。

|-- openadsdk        # 这是白鹭项目
|-- openadsdk-android    # 这是白鹭发布的 EgretNative项目
|-- openadsdk_demo.apk    # 这是生成的APK文件,开发者可以直接安装预览效果

工程配置

参考穿山甲官方接入文档,或直接修改使用提供的android工程,并在Adcode.java文件中对应设置好应用id和代码位code。

使用方法

步骤1:导入egret示例项目中的src/openadsdk;
步骤2:在您的egret项目中恰当的位置直接调用相关静态方法。
目前包含五种广告接入
1、SplashAd: 开屏广告
设置您安卓工程中的AndroidManifest.xml文件,将SplashActivity作为启动,并在需要的情况下修改该文件的goToMainActivity()方法跳转到您指定的活动。值得注意的是,虽然sdk中提供了调起开屏广告的api,但不应该这样做,它并不像其他广告类型那样需要主动唤起。


   
     
     
   

2、RewardVideoAd:激励视频广告激励广告需要设置如下参数,当回调事件参数的event属性值为"onRewardVerify"时,会返回您需要的数据,如"verify",它表示奖励是否有效。

//激励广告
     const data = {
       is_horizontal: false,//是否为横屏广告
       userID: "user0",//用户id
       rewardAmount: 1,//奖励数量
       rewardName: "金币"//奖励名称
     }
     openadsdk.RewardVideoAd((json) => {
       console.log("激励广告事件:" + json)
       const data = JSON.parse(json);
       if(data.event === "onRewardVerify"){
         const verify =data.verify;//是否有效
         const amount =data.amount;//奖励数量
         const name =data.name;//奖励名称
       }else if(data.event === "onAdShow"){
         console.log("广告显示")
       }else if(data.event === "onAdVideoBarClick"){
         console.log("点击banner")
       }else if(data.event === "onAdClose"){
         console.log("关闭广告")
       }else if(data.event === "onVideoComplete"){
         console.log("视频播放完毕")
       }else if(data.event === "onVideoError"){
         console.log("视频播放错误")
       }else if(data.event === "onSkippedVideo"){
         console.log("跳过")
       }
     }, this, JSON.stringify(data))

3、FullScreenVideoAd: 全屏视频广告设置参数:是否为横屏。

//全屏广告
     const data = {
       is_horizontal: false,//是否为横屏广告
     }
     openadsdk.FullScreenVideoAd((json) => {
       console.log("全屏广告事件:" + json)
     }, this, JSON.stringify(data))

4、BannerExpressAd: banner广告参数包括是否在屏幕顶部,宽度,高度,【尺寸请和平台设置保持一致】。

//banner广告
     const data = {
       is_top:false,
       width:600,
       height:90
     }
     openadsdk.BannerExpressAd((json) => {
       console.log("banner广告事件:" + json)
     }, this, JSON.stringify(data))

5、InteractionAd: 插屏广告参数包括宽度,高度,【尺寸请和平台设置保持一致】。

//插屏广告
     const data = {
       width:900,
       height:900
     }
     openadsdk.InteractionAd((json) => {
       console.log("插屏广告事件:" + json)
     }, this, JSON.stringify(data))

步骤3:发布到对应android工程中

关于返回事件

在egret项目中,广告回调的参数为json格式的字符串,其中event属性说明了该事件的类型,类型说明如下,这边只是转发了穿山甲sdk原生的协议回调,并不是所有类型广告都包含如下事件类型,如:激励广告无法跳过,banner广告没有视频类消息,ios和android也不尽相同,提供的原生工程对广告的封装实现也是直接复制了穿山甲提供的工程源码,所以,请严格测试,参考原生代码,合理使用回调事件。

onAdClicked            //广告点击
onAdShow              //广告出现
onAdDismiss            //插屏广告关闭
onError              //错误
onSelected             //banner关闭按钮
onCancel              //点击取消
onAdVideoBarClick         //视频类bar点击
onAdClose             //广告关闭
onVideoComplete          //视频类播放完成
onVideoError            //视频类错误
onRewardVerify           //激励确认
onSkippedVideo           //视频类跳过

iOS

下载示例Demo

白鹭引擎已经为开发者提供了示例Demo,开发者可以直接基于该Demo 学习如何接入穿山甲广告SDK。demo项目包含一个egret工程,一个ios工程。

工程配置

参考穿山甲官方接入文档,或直接修改使用提供的ios工程,这里详细走一遍官方提供的CocoaPods流程。

步骤1:安装cocoapods

gem install cocoapods

步骤2:下载Git LFS ,解压,安装

sudo sh install.sh

步骤3:cd到你的xcode工程中创建Podfile文件写入如下,这里的'openadsdk'是xcode工程的项目target,也就是egret发布中填写的应用名称。

source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '8.0'

target 'openadsdk' do
   pod 'Bytedance-UnionAD'
end

步骤4:pod install

pod install

注:不同网络环境下pod的安装速度会有较大差异,首次安装会有大概2G左右的文件下载,请耐心等待,并通过活动监视器查看下载速度,若速度过慢,请考虑设置git代理,或自行clone可用仓库到本地。

步骤5:打开ios-template.xcworkspace

步骤6:参照官方接入中心IOS-SDK接入文档中的《Xcode编译选项设置》完成剩余工程配置

步骤7:文件修改

1:将示例ios工程中的ios-template/sdk文件夹导入到您的ios工程中;

2:参照示例ios工程中的AppDelegate.h修改您ios工程的对应文件;

3:为AppDelegate.mm添加如下两个方法;

-(void)initJSEvent:(EgretNativeIOS*)native{
   NSLog(@"InitJSEvent");
}
-(void)InitAD:(UIViewController*)root{
   NSLog(@"InitAD");
}

并在didFinishLaunchingWithOptions中调用

//init
[self initJSEvent:_native];
[self InitAD:viewController];
return true;

4:在sdk/AdManager.h文件中设置您的广告信息,如appKey,XXX_ID。

使用方法

目前包含五种广告接入SplashAd: 开屏广告开屏广告的入口函数调用位于:

AppDelegate-Category.m                //文件
   -(void)setupBUAdSDK{}              //方法
     [self addSplashAD];             //语句

请根据需要注释或保留,值得注意的是,虽然sdk中提供了调起开屏广告的api,但不应该这样做,它并不像其他广告类型那样需要主动唤起。

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


本文名称:怎样在EgretNative中接入广告SDK?-创新互联
文章URL:http://csdahua.cn/article/dpgjcd.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流