H5页面调用admob激励视频,用户获取奖励
应用前提条件
- 使用 Android Studio 3.2 或更高版本
确保您应用的 build 文件使用以下值:
minSdkVersion
为16
或更高版本compileSdkVersion
为28
或更高版本
1,在您的项目级 build.gradle
文件中,同时在 buildscript
和 allprojects
两个部分中添加
buildscript {
repositories {
google()
mavenCentral()
}
} allprojects {
repositories {
google()
mavenCentral()
}
}
2,将 Google 移动广告 SDK 的依赖项添加到您的模块的应用级 Gradle 文件,通常为 app/build.gradle:
dependencies {
implementation 'com.google.android.gms:play-services-ads:21.0.0'
}
3,将您的 AdMob 应用 ID(可在 AdMob 界面中找到)添加到应用的 AndroidManifest.xml
文件中。为此,请添加包含 android:name="com.google.android.gms.ads.APPLICATION_ID"
的 <meta-data>
代码。您可以在 AdMob 界面中找到您的应用 ID。对于 android:value
,请插入您自己的 AdMob 应用 ID,并用英文引号括起来。
测试ID:ca-app-pub-3940256099942544~3347511713
注意:开发工程一定要使用测试ID,不要使用线上ID,否则可能导致线上admob广告流量无效,最严重导致封号!
<manifest>
<application>
<!-- Sample AdMob app ID: ca-app-pub-3940256099942544~3347511713 -->
<meta-data
android:name="com.google.android.gms.ads.APPLICATION_ID"
android:value="ca-app-pub-xxxxxxxxxxxxxxxx~yyyyyyyyyy"/>
</application>
</manifest>
4,初始化广告和预加载激励视频
import com.google.android.gms.ads.MobileAds;
import com.google.android.gms.ads.initialization.InitializationStatus;
import com.google.android.gms.ads.initialization.OnInitializationCompleteListener; public class MainActivity extends AppCompatActivity { private AdRequest adRequest; private Handler mHandler;
private WebView webview; protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); MobileAds.initialize(this, new OnInitializationCompleteListener() {
@Override
public void onInitializationComplete(InitializationStatus initializationStatus) {
}
}); adRequest = new AdRequest.Builder().build();
loadJiliAd(); //ad必须在主线程上,使用消息通知调用
mHandler = new Handler() {
@Override
public void handleMessage(Message msg) {
switch (msg.what) {
case 0:
// 显示广告
showJiliad();
break;
case 1:
//测试加载js
webview.loadUrl("javascript:test()");
break; default:
break;
}
}
}; //加载页面
showWeb(); } private void showJiliad(){
if (mRewardedAd != null) {
Activity activityContext = this;
mRewardedAd.show(activityContext, new OnUserEarnedRewardListener() {
@Override
public void onUserEarnedReward(@NonNull RewardItem rewardItem) {
// 用户获得奖励
Log.d("TAG", "The user earned the reward.");
int rewardAmount = rewardItem.getAmount();
String rewardType = rewardItem.getType();
showJiangli("恭喜获得奖励"); }
});
}else{
showJiangli("广告拉取中,请稍候再试");
loadJiliAd();
}
}
private void showJiangli(String msg){
Toast.makeText(this,msg,Toast.LENGTH_SHORT).show();
} private void showWeb(){ //实例化WebView对象
webview = new WebView(this);
//设置WebView属性,能够执行Javascript脚本 WebSettings webSettings = webview.getSettings();
webSettings.setJavaScriptEnabled(true); //加载页面
webview.loadUrl("https://xxx.com/"); //WebAppInterface 是我们自定义的一个类,通过实例化一个WebAppInterface 对象来和html进行绑定
WebAppInterface webAppInterface = new WebAppInterface(this,mHandler);
webview.addJavascriptInterface(webAppInterface, "Android"); webview.setWebViewClient(new WebViewClient(){
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url){
view.loadUrl(url);
return true;
}
}); webview.setWebViewClient(new WebViewClient()
{
Random ra =new Random();
int r = ra.nextInt(20) + 1 ; @Override
public void onPageFinished(WebView view, String url)
{
//结束
super.onPageFinished(view, url);
Log.d("TAG", "加载结束"); if(r == 10){
showAD();
}
}
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon)
{
//开始
super.onPageStarted(view, url, favicon);
Log.d("TAG", "加载开始");
num ++;
if(r == 6){
if (mInterstitialAd != null) {
showAD();
}
}else if(num >= 6){
if (mInterstitialAd != null) {
num =0;
showAD();
}else{
Log.d("TAG", "广告未加载成功");
}
} Log.d("TAG", "加载NUM:" + String.valueOf(num)); }
}); private void loadJiliAd(){
RewardedAd.load(this, "ca-app-pub-3940256099942544/5224354917",
adRequest, new RewardedAdLoadCallback() {
@Override
public void onAdFailedToLoad(@NonNull LoadAdError loadAdError) {
// Handle the error.
Log.d("TAG", loadAdError.toString());
mRewardedAd = null;
} @Override
public void onAdLoaded(@NonNull RewardedAd rewardedAd) {
mRewardedAd = rewardedAd;
Log.d("TAG", "Ad was loaded."); mRewardedAd.setFullScreenContentCallback(new FullScreenContentCallback() {
@Override
public void onAdClicked() {
// 在为广告记录点击时调用。
Log.d("TAG", "Ad was clicked.");
} @Override
public void onAdDismissedFullScreenContent() {
// 当广告被关闭时调用.
// 将广告引用设置为 null,这样您就不会再次展示广告。
Log.d("TAG", "Ad dismissed fullscreen content.");
mRewardedAd = null;
} @Override
public void onAdFailedToShowFullScreenContent(AdError adError) {
// 广告无法展示时调用
Log.e("TAG", "Ad failed to show fullscreen content.");
mRewardedAd = null;
} @Override
public void onAdImpression() {
// 在为广告记录展示时调用
Log.d("TAG", "Ad recorded an impression.");
} @Override
public void onAdShowedFullScreenContent() {
// 显示广告时调用.
Log.d("TAG", "Ad showed fullscreen content."); }
});
}
});
}
}
6,webAppInterface类
public class WebAppInterface {
Activity mContext; Handler mHandler;
/**
* Instantiate the interface and set the context
*/
WebAppInterface(Activity c,Handler r) {
mContext = c;
mHandler = r;
} /**
* js调用Android的函数
*/
@JavascriptInterface
public void startFunction() {
Toast.makeText(mContext,"我是安卓原生的弹窗",Toast.LENGTH_SHORT).show(); //调用激励视频广告
Message msg = new Message();
msg.what = 0;
mHandler.sendMessage(msg); }
/**
* js调用Android的函数并给Android原生传递一个参数
*/
@JavascriptInterface
public void startFunction(String arg) {
Toast.makeText(mContext,arg,Toast.LENGTH_SHORT).show();
}
}
7,html调用激励奖励
<input type="button" value="点击调用android代码,拉取激励视频"
onclick="window.Android.startFunction()"/>
整体流程结束,业务代码可按需自行添加
H5页面调用admob激励视频,用户获取奖励的更多相关文章
- 在Angular.js中的H5页面调用Web api时跨域问题处理
/// <summary> /// 被请求时 /// 在Angular.js中的H5页面调用Web api时跨域问题处理 /// </summary> /// <para ...
- 前端如何在h5页面调用微信支付?
在微信服务号开发的时候经常会遇到微信支付的功能实现,通过实际经验自己总结了一下,前端在H5页面调起微信支付有两种办法,一是利用内置对象,二是通过引用微信的js sdk,亲测都能支付成功,从写法上来看用 ...
- 微信h5页面调用第三方位置导航
微信h5页面拉起第三方导航应用 需要准备的: 通过微信认证的公众号有备案过的域名 背景:微信公众号点击菜单栏跳到h5页面,需要用到导航功能 需求:当用户点击导航按钮时,跳转到第三方app进行导航 参考 ...
- Webview之H5页面调用android的图库及文件管理
h5页面打开图片管理器 一般页面在pc打开文件管理器是用 type="file"的代码,可是这在android的webview是无效的,必须为webview设定WebChromeC ...
- 混合app开发,h5页面调用ios原生APP的接口
混合APP开发中,前端开发H5页面,不免会把兼容性拉进来,在做页面的兼容性同事,会与原生app产生一些数据交互: 混合APP开发,安卓的兼容性倒是好说,安卓使用是chrome浏览器核心,已经很好兼容H ...
- h5页面 video暂停播放 视频控件 以及当前页面只有一个可以播放效果
<!DOCTYPE html> <html> <head> <meta name="viewport" content="wid ...
- H5页面调用手机打电话功能
<head>里面加上: <meta name="format-detection" content="telephone=yes"/> ...
- h5页面调用摄像头(简易版)
<input type="button" value="OpenVideo" id="btnOpenVideo" /> < ...
- h5页面调用相机功能
//accept:表示要打开的文件类型 capture:表示可以捕获到系统默认的设备 <input type="file" accept="image/*" ...
随机推荐
- Python程序入口 __name__ == ‘__main__‘ 有重要功能(多线程)而非编程习惯
文章来源于互联网(https://jq.qq.com/?_wv=1027&k=rX9CWKg4) 在Python中,被称为「程序的入口」的 if name =='main': 总是出现在各种示 ...
- 单片机 MCU 固件打包脚本软件
1 前言 开发完 MCU 软件后,通常都会生成 hex 文件或者 bin 文件,用来做固件烧录或者升级,如果用来做产品开发,就涉及到固件版本的问题,初学者通常采用固件文件重命名来区分版本. 如果需 ...
- -bash: /usr/local/maven/apache-maven-3.8.1/bin/mvn: 权限不够
chmod a+x /usr/local/maven/apache-maven-3.8.1/bin/mvn
- 密码学系列之:在线证书状态协议OCSP详解
目录 简介 PKI中的CRL CRL的缺点 CRL的状态 OCSP的工作流程 OCSP的优点 OCSP协议的细节 OCSP请求 OCSP响应 OCSP stapling 总结 简介 我们在进行网页访问 ...
- Mybatis整合第三方缓存
1) 为了提高扩展性.MyBatis定义了缓存接口Cache.我们可以通过实现Cache接口来自定义二级缓存 2) EhCache 是一个纯Java的进程内缓存框架,具有快速.精干等特点. 3) 整合 ...
- Qt点名器
项目已开源,点击跳转 废话不多说,直接上代码. CMakeLists.txt cmake_minimum_required(VERSION 3.10) project(qt-caller) find_ ...
- SimpleMongoDbFactory类已经失效,被SimpleMongoClientDbFactory替代
老版本的mongodbtemplate连接池的用法 spring: data: mongodb: address: 127.0.0.1:37017 replica-set: database: xxx ...
- VS Code + GitHub
来到博客园学着别人美化了一下自己的博客页面,蛮好看的,然后右上角有一个"Fork me on GitHub".之前就因为好奇而注册过GitHub,但一直不会使,现在正式开始编程学习 ...
- 如何在Excel批量查询电话号码归属地?
手机号码归属地的重要性大家应该都清楚,如果取消或者更改手机号码归属地,那么一会增加用户的被诈骗风险;二是对套餐资费会产生影响,加剧企业间的竞争,加剧数字鸿沟;三是企业运营管理需要投入大量人力物力,是个 ...
- angular变化检测OnPush策略需要注意的几个问题
OnPush组件内部触发的事件(包括viewChild)会引起组件的一次markForCheck Detached组件内部触发的事件不会引起组件的变化检测 OnPush组件的contentChild依 ...