开篇
这里给出一篇App从后台切换到前台显示全屏广告的实践报告!
这里主要做两件事情:
- 1、如何监听前后台切换
- 2、实现倒计时全屏广告
效果截屏
立即体验
扫描以下二维码下载体验App(从0.2.3
版本开始,体验App内嵌版本更新检测功能):
JSCKit库传送门:https://github.com/JustinRoom/JSCKit
实施步骤
- 1、前后台切换监听
关于如何监听前后台切换,请跳转查看这篇文章:android实现应用程序前台和后台之间转换的监听的两种方式。这里选择了在Application
中注册ActivityLifecycleCallbacks
监听的方式:
public class MyApplication extends Application {
public static final long ADVERTISEMENT_INTERNAL_TIME = 2 * 60 * 60 * 1000;//2小时
private final String TAG = getClass().getSimpleName();
private int mFinalCount;
private ArrayMap advertisementFilter = new ArrayMap<>();
private ActivityLifecycleCallbacks activityLifecycleCallbacks = new ActivityLifecycleCallbacks() {
@Override
public void onActivityCreated(Activity activity, Bundle savedInstanceState) {
}
@Override
public void onActivityStarted(Activity activity) {
mFinalCount++;
Log.e(TAG, "onActivityStarted: " + activity.getClass().getSimpleName() + ">>>" + mFinalCount);
if (mFinalCount == 1 && canShowAdvertisement(activity.getClass())) {
//如果是PhotoActivity时,在开启相机或者打开相册返回时不显示广告
//onActivityResult(int requestCode, int resultCode, Intent data)在onActivityStarted(Activity activity)方法前调用,
//所以不能在onActivityResult(int requestCode, int resultCode, Intent data)中设置enableAdvertisement = true
if (activity instanceof PhotoActivity && !((PhotoActivity) activity).enableAdvertisement){
((PhotoActivity) activity).enableAdvertisement = true;
return;
}
//说明从后台回到了前台
long lastShowAdvertisementTimeStamp = SharePreferencesUtils.getInstance().getLong(Configration.SP_ADVERTISEMENT_LAST_SHOW_TIME, 0L);
long curTime = System.currentTimeMillis();
if ((curTime - lastShowAdvertisementTimeStamp > ADVERTISEMENT_INTERNAL_TIME)) {
SharePreferencesUtils.getInstance().saveLong(Configration.SP_ADVERTISEMENT_LAST_SHOW_TIME, curTime);
activity.startActivity(new Intent(activity, AdvertisementViewActivity.class));
}
}
}
@Override
public void onActivityResumed(Activity activity) {
}
@Override
public void onActivityPaused(Activity activity) {
}
@Override
public void onActivityStopped(Activity activity) {
mFinalCount--;
// Log.e(TAG, "onActivityStopped: " + activity.getClass().getSimpleName() + ">>>" + mFinalCount);
if (mFinalCount == 0) {
//说明从前台回到了后台
}
}
@Override
public void onActivitySaveInstanceState(Activity activity, Bundle outState) {
}
@Override
public void onActivityDestroyed(Activity activity) {
}
};
@Override
public void onCreate() {
Log.e(TAG, "onCreate()");
super.onCreate();
InstanceManager.getInstance().init(this);
//初始化SharedPreferences工具
SharePreferencesUtils.getInstance().init(this, "share_data");
//注册activity生命周期监听
if (BuildConfig.enableAdvertisementFeature) {
registerActivityLifecycleCallbacks(activityLifecycleCallbacks);
//启动界面不显示广告页
addToAdvertisementFilter(LaunchActivity.class);
addToAdvertisementFilter(AdvertisementViewActivity.class);
}
}
/**
* Add activity to advertisement filter.
*
* @param clazz clazz
*/
public void addToAdvertisementFilter(Class extends Activity> clazz) {
String key = clazz.getName();
String activityName = clazz.getSimpleName();
if (!advertisementFilter.containsKey(key))
advertisementFilter.put(key, activityName);
}
/**
* Remove activity from advertisement filter.
*
* @param clazz clazz
*/
public void removeFromAdvertisementFilter(Class extends Activity> clazz) {
String key = clazz.getName();
if (advertisementFilter.containsKey(key))
advertisementFilter.remove(key);
}
private boolean canShowAdvertisement(Class extends Activity> clazz){
String key = clazz.getName();
return !advertisementFilter.containsKey(key);
}
}
当
mFinalCount
值为1时,应用从后台回到了前台。
当mFinalCount
值为0时,应用从前台回到了后台。
- 2、倒计时全屏广告
在app启动加载界面的时,调用后台接口,并下载好下次要显示的广告图片
广告多为图片形式展示,所以在显示广告之前我们要先下载好广告图片到本地,因为广告图片都是一些高质量图片,非常大。如果我们选择在显示的时候临时下载,耗时比较多,用户体验性非常之差。至于下载图片的方式很多,比如说一些第三方的图片加载框架:Picsso、ImageLoader、fresco...,也可以用下载文件的方式下载。
有了广告图片 ,接下来我们要做的就是显示倒计时全屏广告
全屏广告实现的方式也很多:
- Dialog方式
- WindowManager方式
- Activity方式
本示例选择的是以Activity的形式展示,简单方便!示例中,我自己封装了一个简单的倒计时广告控件,如果你的要求也不是那么复杂的话,它就够用了!----AdvertisementView。具体使用实践请参考界面AdvertisementViewActivity!
控制全屏广告的显示
这里只要加一些自己的需求逻辑,按需求显示广告就行了!比如说我们的广告图片是否已经下载完成、距离上一次显示广告时间间隔最少需要3分钟...
@Override
public void onActivityStarted(Activity activity) {
mFinalCount++;
Log.e(TAG, "onActivityStarted: " + activity.getClass().getSimpleName() + ">>>" + mFinalCount);
if (mFinalCount == 1 && canShowAdvertisement(activity.getClass())) {
//如果是PhotoActivity时,在开启相机或者打开相册返回时不显示广告
//onActivityResult(int requestCode, int resultCode, Intent data)在onActivityStarted(Activity activity)方法前调用,
//所以不能在onActivityResult(int requestCode, int resultCode, Intent data)中设置enableAdvertisement = true
if (activity instanceof PhotoActivity && !((PhotoActivity) activity).enableAdvertisement){
((PhotoActivity) activity).enableAdvertisement = true;
return;
}
//说明从后台回到了前台
long lastShowAdvertisementTimeStamp = SharePreferencesUtils.getInstance().getLong(Configration.SP_ADVERTISEMENT_LAST_SHOW_TIME, 0L);
long curTime = System.currentTimeMillis();
if ((curTime - lastShowAdvertisementTimeStamp > ADVERTISEMENT_INTERNAL_TIME)) {
SharePreferencesUtils.getInstance().saveLong(Configration.SP_ADVERTISEMENT_LAST_SHOW_TIME, curTime);
activity.startActivity(new Intent(activity, AdvertisementViewActivity.class));
}
}
}
到这里,很简单,很粗暴地就完成了切换到前台显示全屏广告需求设计了。我的Github
上的demo有完整的实现过程,请自行参考!如果你没有看懂的话,请给我留言或者联系我,谢谢!
篇尾
QQ:1006368252。
最大的挑战和突破在于用人,而用人最大的突破在于信任人。——马云