これが、バナー広告をロードしようとしているクラス全体です(createAd()メソッドが機能します)。
public class HomeActivity extends Activity {
private HomeView homeView;
private ImageView playButton;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);
// playButton = (ImageView)findViewById(R.id.playButton);
// playButton.setImageBitmap(BitmapFactory.decodeResource(getResources(),
// R.drawable.play));
// setListener();
setContentView(R.layout.home_main);
createAd();
}
private void setListener (){
playButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
playButton.setImageBitmap(BitmapFactory.decodeResource(getResources(),
R.drawable.play2));
playGame();
}
});
}
private void createAd(){
setContentView(R.layout.home_main);
AdView adView = (AdView)findViewById(R.id.bottomAd);
AdRequest.Builder adRequestBuilder = new AdRequest.Builder();
adRequestBuilder.addTestDevice("FEACCF89D31180ABDD853C9C3DD2E871");
// .addTestDevice("1744314CD0C7B0619F94D44CE2E5093E");
adView.loadAd(adRequestBuilder.build());
}
public void playGame() {
SharedPreferences savedData = getApplicationContext()
.getSharedPreferences("lastScore", Context.MODE_PRIVATE);
int score = savedData.getInt("lastScore", Context.MODE_PRIVATE);
Intent intent = new Intent(HomeActivity.this, GamePlay.class);
intent.putExtra("lastScore", score);
startActivity(intent);
finish();
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}
ここにhome_mainのxmlがあります
<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
xmlns:tools="http://schemas.Android.com/tools"
Android:id="@+id/homeRelative"
Android:layout_width="match_parent"
Android:layout_height="wrap_content"
Android:paddingBottom="@dimen/activity_vertical_margin"
Android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".HomeActivity">
<com.google.Android.gms.ads.AdView
xmlns:ads="http://schemas.Android.com/apk/res-auto"
Android:id="@+id/bottomAd"
Android:layout_width="fill_parent"
Android:layout_height="wrap_content"
ads:adSize="SMART_BANNER"
ads:adUnitId="@string/admob_banner_id">
</com.google.Android.gms.ads.AdView>
</RelativeLayout>
ここに最新の実行後の私のログがあります
01-01 16:00:32.235 26387-26387/com.rune.colorhunt D/OpenGLRenderer﹕ Enabling debug mode 0
01-01 16:00:32.275 652-796/? I/CrashAnrDetector﹕ onPackageUpdateFinished : com.rune.colorhunt
01-01 16:00:37.351 26387-26416/com.rune.colorhunt D/dalvikvm﹕ DexOpt: --- BEGIN 'ads976472321.jar' (bootstrap=0) ---
01-01 16:00:37.361 26387-26387/com.rune.colorhunt V/WebViewChromium﹕ Binding Chromium to the main looper Looper (main, tid 1) {41d00b38}
01-01 16:00:37.361 26387-26387/com.rune.colorhunt I/chromium﹕ [INFO:library_loader_hooks.cc(112)] Chromium logging enabled: level = 0, default verbosity = 0
01-01 16:00:37.361 26387-26387/com.rune.colorhunt I/BrowserProcessMain﹕ Initializing chromium process, renderers=0
01-01 16:00:37.391 26387-26426/com.rune.colorhunt W/chromium﹕ [WARNING:proxy_service.cc(888)] PAC support disabled because there is no system implementation
01-01 16:00:37.421 26387-26387/com.rune.colorhunt I/Ads﹕ Starting ad request.
01-01 16:00:37.441 26387-26416/com.rune.colorhunt D/dalvikvm﹕ DexOpt: --- END 'ads976472321.jar' (success) ---
01-01 16:00:37.441 26387-26416/com.rune.colorhunt D/dalvikvm﹕ DEX prep '/data/data/com.rune.colorhunt/cache/ads976472321.jar': unzip in 0ms, rewrite 91ms
01-01 16:00:37.611 26387-26394/com.rune.colorhunt I/dalvikvm﹕ Total arena pages for JIT: 11
01-01 16:00:37.611 26387-26394/com.rune.colorhunt I/dalvikvm﹕ Total arena pages for JIT: 12
01-01 16:00:37.621 26387-26394/com.rune.colorhunt I/dalvikvm﹕ Total arena pages for JIT: 13
01-01 16:00:37.621 26387-26394/com.rune.colorhunt I/dalvikvm﹕ Total arena pages for JIT: 14
01-01 16:00:37.651 26387-26431/com.rune.colorhunt W/Ads﹕ There was a problem getting an ad response. ErrorCode: 2
01-01 16:00:37.691 26387-26387/com.rune.colorhunt I/Ads﹕ Scheduling ad refresh 60000 milliseconds from now.
01-01 16:00:37.691 26387-26387/com.rune.colorhunt W/Ads﹕ Failed to load ad: 2
01-01 16:01:37.715 26387-26387/com.rune.colorhunt I/Ads﹕ Starting ad request.
01-01 16:01:37.825 26387-26490/com.rune.colorhunt W/Ads﹕ There was a problem getting an ad response. ErrorCode: 2
01-01 16:01:37.845 26387-26387/com.rune.colorhunt I/Ads﹕ Scheduling ad refresh 60000 milliseconds from now.
01-01 16:01:37.845 26387-26387/com.rune.colorhunt W/Ads﹕ Failed to load ad: 2
01-01 16:02:37.889 26387-26387/com.rune.colorhunt I/Ads﹕ Starting ad request.
01-01 16:02:38.009 26387-26531/com.rune.colorhunt W/Ads﹕ There was a problem getting an ad response. ErrorCode: 2
01-01 16:02:38.039 26387-26387/com.rune.colorhunt I/Ads﹕ Scheduling ad refresh 60000 milliseconds from now.
01-01 16:02:38.039 26387-26387/com.rune.colorhunt W/Ads﹕ Failed to load ad: 2
01-01 16:03:38.972 26387-26387/com.rune.colorhunt I/Ads﹕ Starting ad request.
01-01 16:03:39.062 26387-26783/com.rune.colorhunt W/Ads﹕ There was a problem getting an ad response. ErrorCode: 2
01-01 16:03:39.062 26387-26387/com.rune.colorhunt I/Ads﹕ Scheduling ad refresh 60000 milliseconds from now.
01-01 16:03:39.062 26387-26387/com.rune.colorhunt W/Ads﹕ Failed to load ad: 2
誰かが私を助けてくれるなら、それは素晴らしいことです。私は文字通り何が問題なのか全くわかりません。多分私は何か非常にシンプルなものを逃していて、ちょうどもう一組の目が必要です。助けてくれてありがとう、ありがとう。
デバイスがインターネットに正しく接続されていることを確認します。インターネット接続がないと、広告を取得できません。
Admob広告が読み込まれません。デバイスで日付または時刻が間違っている場合、エラー2が表示されます。デバイスで自動日付修正を設定するだけです
エラー2はERROR_CODE_NETWORK_ERROR
を意味します。だからあなたのインターネット接続をチェックし、それでも広告が表示されないなら、ただあなたの携帯電話を再起動してチェックしてください...それは私のためにうまくいきました。
この投稿で提案されているように、別の問題はadblockerアプリケーションである可能性があります: https://stackoverflow.com/a/36010639/3596576 by @Durian。
私にとってこれが問題でした。
実際のデバイスを使用している場合は、他のアプリも確認してください。広告が表示されている場合は、アプリに広告が含まれていることがわかります。また、モバイルネットワークとWi-Fiで個別に確認してください。
私にとっては、モバイルネットワークとすべてのアプリでのみ表示されるわけではありません。 Google Play Servicesのデータを削除する助けてください。広告が再び表示され始めます。 GPSがデータをダウンロードするまで。したがって、約1分間機能しました。 :-D
この動作は、アプリが一度に大量の広告リクエストを行うために発生し、SDKの状態が悪くなります。すべてのデータを消去することで効果的に実行できるGoogle Playサービスを再起動すると、問題が解決します。この問題のSDK修正は、次のGoogle Play開発者サービスリリースに含まれる予定です。デバイスがアップデートを取得したら、アプリを更新する必要はありません。 これはSDKの既知の問題です
最初に、ロードするアドのタイプ、インタースティシャル、またはバナー広告について明確にします。バナー広告をロードする場合は、admobサイトでバナーad_unit_idを作成し、以下のようにアクティビティビュー内で直接AdViewを使用します。
<com.google.Android.gms.ads.AdView
xmlns:ads="http://schemas.Android.com/apk/res-auto"
Android:id="@+id/xadView"
Android:layout_width="fill_parent"
Android:layout_height="wrap_content"
ads:adSize="SMART_BANNER"
ads:adUnitId="@string/admob_banner_ad_unit_id" />
以下のように、コードからバナー広告の読み込みをリクエストするだけです:setcontentviewの後に、oncreate内のアクティビティにこのコードを記述します
AdView mAdView = (AdView) findViewById(R.id.xadView);
AdRequest adRequest = new AdRequest.Builder().addTestDevice(
AdRequest.DEVICE_ID_EMULATOR).build();
mAdView.loadAd(adRequest);
[〜#〜]および[〜#〜]
インタースティシャル広告をロードする場合は、AdMobサイトでインタースティシャルad_unit_idを作成し、以下のメソッドで使用します。
public void showFullScreenAd() {
try {
com.google.Android.gms.ads.InterstitialAd interstitial = new com.google.Android.gms.ads.InterstitialAd(context);
interstitial
.setAdUnitId(ADMOB_INTERSTITIAL_AD_UNIT_ID);
// Check the logcat output for your hashed device ID to get test ads
// on
// a physical device.
com.google.Android.gms.ads.AdRequest adRequest = new AdRequest.Builder()
.build();
// Load the interstitial ad.
interstitial.loadAd(adRequest);
interstitial
.setAdListener(new com.google.Android.gms.ads.AdListener() {
@Override
public void onAdLoaded() {
interstitial.show();
}
});
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
注意:インタースティシャル広告内でバナー広告ユニットIDを使用したり、バナー広告内でインタースティシャル広告ユニットIDを使用したりすることがあるため、このエラーが発生します。
同様の問題がありました。インターネット接続は問題なく、広告ブロッカーはインストールされていませんでした。
問題はテストデバイスに関連している可能性があります。テストデバイスにAdmobを含む別のアプリケーションがあるかどうかを確認します。 Admobを含む別のデバイスや別のアプリで確認することもできます。
私の場合、テストデバイスはインターネットに接続されているが、さまざまなアプリケーションでAdmob広告が表示されないことに気付きました。だから私は私のテストデバイスを再起動しようとしました、そしてそれはうまくいきました。
物理的なテストデバイスの画面に広告が表示されないという同じ問題がありました。
Wi-Fiをオフにして3gモバイルデータの使用を開始すると、物理的なテストデバイスに広告が表示され始めました。
依存関係にも違いがあります。
com.google.Android.gms:play-services-ads:9.2.0
の代わりに 11.6.2
Android Studioのエミュレータでは、デバイスの仮想ロケーションが間違っていました。実際のロケーションとして設定すると、デバイスが機能し始めました。
私たちのケースでは、ファイアウォールで広告をブロックするための設定がいくつかありました。ファイアウォールのないオープンなインターネット接続に切り替えたときに機能しました。
グーグルサービスで無効に設定されている「モバイルネットワークのバックグラウンドデータを無効にする」を試してください、それは私のために働きます