简体   繁体   English

插页式广告不会让应用启动

[英]interstitial won't let app launch

I've got a problem: I'm trying to add interstitial ads in my app, I thought it would be easy because I already have conventional one and it works perfectly, but something gone wrong.. 我遇到了一个问题:我正在尝试在应用中添加插页式广告,我认为这很容易,因为我已经有了常规广告,并且效果很好,但出了点问题。

Here's my code ( in_app_billing_system ): 这是我的代码( in_app_billing_system ):

 import com.google.android.gms.ads.AdListener;
 import com.google.android.gms.ads.AdRequest;
 import com.google.android.gms.ads.AdSize;
 import com.google.android.gms.ads.AdView;
 import com.google.android.gms.ads.InterstitialAd;
 ...
 ...
 ...
 mInterstitialAd = new InterstitialAd(this);
 mInterstitialAd.setAdUnitId("ca-app-pub-3940256099942544/1033173712");
 AdRequest adRequestI = new AdRequest.Builder().addTestDevice("bla bla bla").build();
 mInterstitialAd.loadAd(adRequestI);

And here's my error: 这是我的错误:

08-07 10:03:00.495 13565-13565/? 08-07 10:03:00.495 13565-13565 /? E/AndroidRuntime﹕ FATAL EXCEPTION: main Process: ****, PID: 13565 java.lang.RuntimeException: Unable to start activity ComponentInfo{*****.ActMain}: java.lang.NullPointerException at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2237) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2286) at android.app.ActivityThread.access$800(ActivityThread.java:144) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1246) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:212) at android.app.ActivityThread.main(ActivityThread.java:5135) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:515) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:877) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:693) at dalvik.system.NativeStart.main(Native Method) Caused by: java.lang.NullPointerException at android.content. E / AndroidRuntime致命异常:主进程:****,PID:13565 java.lang.RuntimeException:无法启动活动ComponentInfo {*****。ActMain}:android.app.ActivityThread上的java.lang.NullPointerException .performLaunchActivity(ActivityThread.java:2237)在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2286)在android.app.ActivityThread.access $ 800(ActivityThread.java:144)在android.app.ActivityThread $ H.handleMessage (ActivityThread.java:1246)在android.os.Handler.dispatchMessage(Handler.java:102)在android.os.Looper.loop(Looper.java:212)在android.app.ActivityThread.main(ActivityThread.java: 5135),位于java.lang.reflect.Method.invokeNative(本机方法),位于com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java.lang.reflect.Method.invoke(Method.java:515)处。 java:877)在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:693)在dalvik.system.NativeStart.main(本机方法) 由以下原因引起: android.content处的java.lang.NullPointerException ContextWrapper.getPackageManager(ContextWrapper.java:94) at com.google.android.gms.common.GooglePlayServicesUtil.isGooglePlayServicesAvailable(Unknown Source) at com.google.android.gms.ads.internal.util.client.zza.zzP(Unknown Source) at com.google.android.gms.ads.internal.client.zze.zzb(Unknown Source) at com.google.android.gms.ads.internal.client.zzz.zzL(Unknown Source) at com.google.android.gms.ads.internal.client.zzz.zza(Unknown Source) at com.google.android.gms.ads.InterstitialAd.loadAd(Unknown Source) at ****.InAppBillingSystem.(InAppBillingSystem.java:46) at ****.ActMain.onCreate(ActMain.java:59) at android.app.Activity.performCreate(Activity.java:5231) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2201) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2286) at android.app.ActivityThread.access$800(ActivityThread.java:144) at android.app.ActivityThread$H. com.google.android.gms.ads.internal.util.client.client.zza.zzP(Unknown)的ContextWrapper.getPackageManager(ContextWrapper.java:94)位于com.google.android.gms.common.GooglePlayServicesUtil.isGooglePlayServicesAvailable(未知源)来源)com.google.android.gms.ads.internal.client.zze.zzb(未知来源)com.google.android.gms.ads.internal.client.zzz.zzL(com.google未知来源) com.google.android.gms.ads.InterstitialAd.loadAd(Unknown Source)的.android.gms.ads.internal.client.zzz.zza(未知源)****。InAppBillingSystem。(InAppBillingSystem.java:46 )****。ActMain.onCreate(ActMain.java:59)在android.app.Activity.performCreate(Activity.java:5231)在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)在android。 app.ActivityThread.performLaunchActivity(ActivityThread.java:2201)在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2286)在android.app.ActivityThread.access $ 800(ActivityThread.java:144)在android.app.ActivityThread $ H。 handleMessage(ActivityThread.java:1246) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:212) at android.app.ActivityThread.main(ActivityThread.java:5135) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:515) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:877) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:693) at dalvik.system.NativeStart.main(Native Method) android.os.Handler.dispatchMessage(Handler.java:102)的handleMessage(ActivityThread.java:1246)android.app.ActivityThread.main(ActivityThread.java)的android.os.Looper.loop(Looper.java:212)处的handleMessage(ActivityThread.java:1246) :5135),位于java.lang.reflect.Method.invokeNative(本地方法),位于com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit)的java.lang.reflect.Method.invoke(Method.java:515) .java:877),位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:693),位于dalvik.system.NativeStart.main(本机方法)

I tried to use original Google code from here but the result is the same. 我尝试从此处使用原始的Google代码,但结果相同。

The code at Line 59 in Main Activity: Main Activity中第59行的代码:

  //INSTALL APP
    if (IS_FIRST_START) tablesInit();

    if (loadFromPref("registered", "").equals("yes")) {
        is_purchased = true;
    } else {
        is_purchased = false;
 **59:    in_app_billing_system = new InAppBillingSystem(this);**
    }

I never used this type of ads, maybe I have missed something? 我从未使用过此类广告,也许我错过了一些东西吗?

PS Don't be confused with name "in_app_billing_system" it's from old times and now I have no in-app but ads there. PS不要与名称“ in_app_billing_system”混淆了,它来自古老,现在我没有应用程序内了,但那里有广告。

It was due to the line: 这是由于以下原因:

mInterstitialAd = new InterstitialAd(this);

Instead what I should have used: 相反,我应该使用的是:

mInterstitialAd = new InterstitialAd(myActivity);

The problem has been solved. 问题已经解决。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM