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/*" ...
随机推荐
- Docker Buildx使用教程:使用Buildx构建多平台镜像
写在前边 记录一下前阵子在X86_64平台使用Docker Buildx构建多平台镜像的办法,包含但不限于构建ARM镜像. 构建环境 软件名 版本 Ubuntu 18.04.2 LTS Docker ...
- 开发实践丨昇腾CANN的推理应用开发体验
摘要:这是关于一次 Ascend 在线实验的记录,主要内容是通过网络模型加载.推理.结果输出的部署全流程展示,从而快速熟悉并掌握 ACL(Ascend Computing Language)基本开发流 ...
- Linux系统安全与应用
补充:重定向 类型 操作符 ...
- 操作表查询&操作表创建&操作表删除&操作表修改
2.操作表 C(create):创建 语法: create table 表明( 列名1 数据类型1, 列名2 数据烈性2, .... 列名n 数据类型n ); create table Student ...
- 理解JavaScript中的window对象
前言 每个JavaScript环境都有一个全局对象(global object).在全局范围内创建的任何变量实际上都是这个对象的属性,而任何函数都是它的方法.在浏览器环境中,全局对象是window对象 ...
- 【Azure 应用服务】本地创建Azure Function Kafka Trigger 函数和Kafka output的HTTP Trigger函数实验
问题描述 在上一篇博文(https://www.cnblogs.com/lulight/p/16525902.html)中,我们成功的以VM作为Kafka服务器运行,并且验证了从其他机器中远程访问.在 ...
- AI全流程开发难题破解之钥
摘要:通过对ModelArts.盘古大模型.ModelBox产品技术的解读,帮助开发者更好的了解AI开发生产线. 本文分享自华为云社区<[大厂内参]第16期:华为云AI开发生产线,破解AI全流程 ...
- 2022-07-29 java之异常
目录 一.异常 1. 异常的概念 2. 异常体系 3.图解异常处理的流程 4.异常处理 1.抛出异常throw 2.捕获异常try{}catch{} 3 声明异常throws 4. finally代码 ...
- Linux、Ubuntu常用命令
# 文件解压缩 # zip压缩目录(附带目录权限) zip -q -r html.zip /home/html 压缩目录 tar -zcvf pack.tar.gz pack/ #打包压缩为一个.gz ...
- NFS 服务器配置(Ubuntu)
# NFS 服务器配置(Ubuntu 20.0) # 1.配置网络环境 # NFS 的客户端和服务端必须在同一局域网 # 2.在服务器上安装nfs sudo apt-get install nfs-c ...