/ADEasy

一套全广告平台的快速集成框架。A fast integration framework for a full advertising platform.

Primary LanguageJavaOtherNOASSERTION

中文 https://github.com/TJHello/ADEasy/blob/master/README.md

English https://github.com/TJHello/ADEasy/blob/master/README-EN.md

手动集成文档(海外平台) https://github.com/TJHello/ADEasy/blob/master/README-MANUAL-v2.md

其他工具说明 https://github.com/TJHello/ADEasy/blob/master/README-TOOLS.md

ADEasy-自动集成说明

QQ交流群(425219113)

使用该程序之前,请仔细阅读:《免责声明与许可协议》


一套全平台广告聚合SDK自动集成框架。

简介:

  • 自动化集成技术,只需要简单控制平台开关就能实现广告接入。并且对于未接入的广告,不会有冗余的代码。
  • 更直观更简洁更高效的对外接口。
  • 可动态根据权重来分配广告位,有效提高收益(可能)。
  • 全局可控广告加载队列,有效提高性能,广告加载数可控。
  • 可精确到某个版本、机型、国家、系统、渠道来控制广告。
  • 可选日志输出,精确定位问题,掌控流程。

目前支持的广告平台:

adMob(banner,interstitial,video,interstitialVideo)

Unity(banner,interstitial,video,interstitialVideo)

Mi(banner,interstitial,video)

GDT(腾讯优量汇2.0)(banner,interstitialVideo,video,splash,native)

Facebook(banner,interstitial,video)

ByteDance(穿山甲)(banner,interstitial,video,interstitialVideo(全屏视频),splash,native)

Vungle(banner,interstitial,video,interstitialVideo)

Baidu(banner,interstitial,video,interstitialVideo,splash)

Oppo(banner,interstitial,video,interstitialVideo,splash)

Vivo(banner,interstitial,video,splash)

Mintegral(banner,interstitial,video,interstitialVideo,splash)

Mintegral-GP(banner,interstitial,video,interstitialVideo,splash)

OneWay(interstitial,video,interstitialVideo,splash,native)

下一步打算支持的广告平台:

IronSource

使用环境


- Android Studio 3.3.1及以上(需要自动化插件版本大于等于6)

- AndroidX(必须,admob等广告强制要求)

- Java/Kotlin(建议Kotlin,专为Kotlin设计,也对Java场景进行了优化)

- JAVA 1.8(建议Java用户使用)

使用步骤

  • Step1 接入自动集成插件到build.gradle(project)

buildscript {
     repositories {
        maven { url 'https://tjhello.gitee.io/publiclib/'}
     }
     dependencies {
        classpath "com.TJHello.plugins:ADEasy:8.3.2102-t42"//8.x版本的插件只支持gradle4.2.x,4.1.x以及以下需要使用7.3.2102-t41版本
     }
}
apply plugin: 'ad-easy'

ADEasyExt{
    adSwitch = true  //广告总开关
    inChina = true //必须-国内true-国外false
    debug = true //该开关关联广告debug开关,release版会自动设置为false
    //以下参数选择性填写,默认false
    //adMobId = "ca-app-pub-xxxxx" //adMob的id,接入admob必填,并且更改成正确的id,否则admob会闪退。
    //adMob = true //admob开关
    adUnity = true //unity开关
    adMi = true //mi广告开关
    adGdt = true //腾讯优量汇开关
    adFacebook = true//Facebook开关
    adByteDance = false//穿山甲开关
    adVungle = false//Vungle开关
    adOppo = false//oppo开关
    adVivo = false//vivo开关
    adMintegral = false//Mintegral-**开关
    adMintegralGp = false//Mintegral-海外开关
    adOneWay = false//OneWay开关
    //umeng = ['key'] //是否让ADEasy托管友盟,['key','deviceType(可选,默认1)','pushSecret(可选,默认null)']
    //abTest = true //ABTest开关 https://github.com/TJHello/ABTest
    //exclude = ['xxxx'] //例外掉某个包
}

android {
    defaultConfig {
        //当方法数超限了
        multiDexEnabled true
    }
    
    //支持java8,可以使用一些便捷的语法糖
    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }
}

dependencies {
    //方法数超限
    implementation 'com.android.support:multidex:1.0.3'
}
class TJApplication : Application(),ADEasyApplicationImp{

    override fun onCreate() {
        super.onCreate()
        ADEasy.setDebug(true)//关联广告平台debug模式,release版会自动设置为false
        ADEasy.setChannel(ADChannel.Order)//关联友盟渠道与某些广告平台的渠道
        ADEasy.toOfflineMode()//离线模式
        ADEasyLog.addFilterType(//添加日志(默认显示基础日志)
            ADEasyLog.TYPE_HANDLER_BASE,
            ADEasyLog.TYPE_ADEASY_DETAILED_STEPS,
            ADEasyLog.TYPE_TOOLS_UMENG
        )
        ADEasy.init(this,this)
    }


    //创建广告配置(必须,离线模式或者获取在线配置失败时用到)
    override fun createAdPlatformConfig(group: String): PlatformConfig? {
        when(group){
            ADInfo.GROUP_ADMOB->{
                return AdConfig.createAdmob()
                     .addParameter("ca-app-pub-3940256099942544/6300978111",ADInfo.TYPE_BANNER)//测试id
                     .addParameter("ca-app-pub-3940256099942544/1033173712",ADInfo.TYPE_INTERSTITIAL)
                     .addParameter("ca-app-pub-3940256099942544/5224354917",ADInfo.TYPE_VIDEO,10)
                     //允许添加多个同类型,不同code的Parameter(Banner暂不支持该特性)
                //   .addParameter("ca-app-pub-394025609994***/**354917",ADInfo.TYPE_VIDEO,10)
                     .initWeight(10)
            }
        }
        return null
    }

    //ADEasy初始化完成,有的方法需要在这里调用才有效果。
    override fun onInitAfter() {
        
    }


    override fun attachBaseContext(base: Context) {
        super.attachBaseContext(base)
        //解决方法数超限问题
        MultiDex.install(base)
    }
}
abstract class AppActivity : AppCompatActivity(),ADEasyActivityImp{
    protected val adEasy by lazy { ADEasy.getInstance(this,this) }

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        adEasy.isAutoShowInterstitial(true)
        onInitValue(savedInstanceState)
        onInitView()
        adEasy.onCreate()
        onLoadData()
    }

    override fun onPause() {
        super.onPause()
        adEasy.onPause()
    }

    override fun onResume() {
        super.onResume()
        adEasy.onResume()
    }

    override fun onDestroy() {
        super.onDestroy()
        adEasy.onDestroy()
    }

    override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
        super.onActivityResult(requestCode, resultCode, data)
        adEasy.onActivityResult(requestCode,resultCode,data)
    }

    override fun onRequestPermissionsResult(
        requestCode: Int,
        permissions: Array<String>,
        grantResults: IntArray
    ) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults)
        adEasy.onRequestPermissionsResult(requestCode,permissions,grantResults)
    }

    protected abstract fun onInitValue(savedInstanceState: Bundle?)

    protected abstract fun onInitView()

    protected abstract fun onLoadData()

    override fun isActivityFinish(): Boolean {
        return isFinishing
    }
    
}
class TestActivity : AppActivity() {

    override fun onInitValue(savedInstanceState: Bundle?) {
        adEasy.isAutoShowBanner(true)
    }

    override fun onInitView() {
        setContentView(R.layout.test_activity_layout)
        btShowVideo.setOnClickListener {
            adEasy.showVideo{adInfo, isReward ->
               Toast.makeText(this,"Close Video :$isReward", Toast.LENGTH_LONG).show()
            }
        }
        btShowInterstitialVideo.setOnClickListener {
            adEasy.showInterstitialVideo {
                Toast.makeText(this,"Close InterstitialVideo",Toast.LENGTH_LONG).show()
            }
        }
        btShowInterstitial.setOnClickListener {
            adEasy.showInterstitial {
                Toast.makeText(this,"Close Interstitial",Toast.LENGTH_LONG).show()
            }
        }

        btShowBanner.setOnClickListener {
            adEasy.showBanner()
        }

        btHideBanner.setOnClickListener {
            adEasy.hideBanner()
        }
    }

    override fun onLoadData() {

    }

    override fun onCreateBanner(): ViewGroup? {
        return bannerLayout
    }

    //退出应用时请调用 ADEasy.exitApp(context)

}

adEasy API说明

boolean hasBanner() //是否有banner
boolean hasInterstitial() //是否有插屏广告
boolean hasVideo() //是否有激励视频
boolean showBanner() //显示banner
boolean showInterstitial() //显示插屏
boolean showInterstitialVideo() //显示插屏视频
boolean showVideo() //显示激励视频
boolean hideBanner() //隐藏banner
void showSplash()//显示开屏
void showNative(ViewGroup viewGroup,String tag,Int position){}//显示原生广告

void hangLifeUp() //挂起生命周期,用于弹起隐私协议等场景,需要在adEasy.onCreate前调用
void hangLifeDown() //放下挂起的生命周期,继续执行
void notShowInterstitialOnce() //忽略一次插屏显示请求,用于第一次进入首页不要显示插屏的场景,需要在adEasy.onCreate前调用
void isAutoShowBanner() //当前页面是否自动显示Banner,需要在adEasy.onCreate前调用
void isAutoShowInterstitial()//当前页面是否自动显示插屏,需要在adEasy.onCreate前调用
void closeAD() //关闭当前页面的广告功能,需要在adEasy.onCreate前调用

ADEasy.init() //初始化接口
ADEasy.agreePrivacy() //同意隐私协议,必须调用
ADEasy.setDebug() //关联广告的debug模式,同时打开日志,release模式下自动设置为false
ADEasy.openLog() //打开日志
ADEasy.toTestMode() //打开测试在线配置模式-仅针对在线模式
ADEasy.setInterstitialTime() //设置插屏自动显示的间隔(毫秒),需要在初始化完成之后调用。
ADEasy.getInstance() //获取一个新的ADEasy实例
ADEasy.changeWeight() //改变某个平台的权重
ADEasy.isInit() //是否初始化完成
ADEasy.getOLParameter() //获取在线参数,需要开启在线功能,并且配置了在线参数
ADEasy.toOfflineMode() //进入离线模式
ADEasy.exitApp() //退出应用的时候调用,关联友盟exit等
ADEasy.setInitListener() //设置一个各广告平台初始化监听器
ADEasy.getConfigManager() //获取广告配置管理器,可以修改广告控制体数值。需要在onInitAfter之后调用。

其他

加QQ群咨询(425219113)

ADEasy版本说明

例:1.0.1001-a01

1:自动化插件版本号[0-99]

0:广告SDK版本更新号[0-999]

1001->主程序版本号

1:框架性修改[0-9]

0:功能性修改[0-99]

01:小修改,bug修复[0-99]

a01->测试版本号

a:alpha测试(经过了内部项目真实环境验证)

b:bate测试(经过了客户真实环境验证)

t:内部测试

SDK版本对应

x.3.xxxx(持续更新中)

~~Yomob(已删除)~~
MI:5.0.6
Unity:3.4.8
ByteDance:3.4.1.0
Admob:19.3.0
GDT:4.310.1180
Vungle:6.7.0
Facebook:5.9.1
Baidu:5.86
Vivo:4.2.0.0
Oppo:3.5.1
Mintegral:14.4.41
OneWay:2.4.5
Huawei:13.4.35.300

x.2.xxxx

Yomob:1.8.7
MI:5.0.0
Unity:3.4.6
ByteDance:3.1.0.0
Admob:19.2.0
GDTSDK:4.232.1102
Vungle:6.7.0
Facebook:5.9.1
Baidu:5.86

x.1.xxxx

Yomob:1.8.7
MI:3.0.0
Unity:3.3.0
ByteDance:2.9.5.0
Admob:19.0.1
GDTSDK:4.190.1060
Vungle:6.5.2
Facebook:5.8.0

x.0.xxxx

Yomob:1.8.5
MI:2.5.0
Unity:3.3.0
ByteDance:2.8.0
Admob:18.3.0
GDTSDK:4.110.980
Vungle:6.5.2
Facebook:5.6.0

自动化插件更新日志

v8

1、支持Android Studio gradle 4.2.x

v7

1、支持AAB模式

v6

1、支持Android Studio gradle 4.1.x

v5

1、重构整个模块,改为纯Kotlin实现。
2、新增oppo、vivo、mintegral、oneWay、huawei,baiDu平台。
3、支持Android Studio 3.3.1-4.0.1

v4

1、修复某些情况下,热修改manifests时,删除条目不生效的问题。
2、修复某些情况下,热修改平台开关,在添加manifests的地方没有动态改变的问题。
3、新增支持百度广告自动化接入。

v3

1、增加对友盟、ABTest,inChina,exclude以及appkey、appToken的支持

主程序更新日志

8.3.2102-t42(持续更新中)

1、修复bug,优化API使用。
2、支持TopOn聚合SDK。
3、迎合国家相关政策,增加ADEasy.agreePrivacy()接口,必须调用

6.3.2102-t09

1、重构代码,将广告平台的逻辑完全分离开来到单独模块。解决了ov联运包检测不通过的问题。
2、新增oppo、vivo、mintegral、huawei、baidu平台,升级多个平台。
3、开放本地控制广告,修改控制体的api。eg:ADEasy.getConfigManager()
4、修复和优化大量问题,系统整体更加稳定了。

4.2.1306-t05 更新时间2020-07-31

1、支持GDT、Bytedance、Baidu的开屏广告
2、支持在代码中修改广告控制配置的参数
3、支持在线功能的测试模式
4、其他的优化

4.2.1304-t03 更新时间2020-06-29

1、全平台SDK升级,新增支持Baidu广告。
2、修复使用在线配置时,可能会报错找不到类的问题。
3、精简与整理代码,优化广告按权加载的整体逻辑。
4、修复Yomob广告回调的问题
5、修复手机品牌判断不准确的问题

4.1.1303-t11 更新时间2020-06-25

1、小bug修复,以及一些细微调整

3.1.1303-t10 更新时间2020-05-20(情人节)

1、新增广告加载线程调度功能
2、新增在线配置功能
3、新增日志打印分级分类功能
4、新增自动化托管友盟的功能
5、新增支持ABTest的功能
6、修复若干bug,大量优化

0.9.xxxx 更新时间:2020-04-09

该命名方式已经遗弃,不再维护