istereo2
changeset 33:3784a2d4bed5
more ad fuckery
author | John Tsiombikas <nuclear@member.fsf.org> |
---|---|
date | Sat, 10 Oct 2015 16:38:19 +0300 (2015-10-10) |
parents | 622f61160016 |
children | 33ba8618972c |
files | src/android/MainActivity.java |
diffstat | 1 files changed, 45 insertions(+), 15 deletions(-) [+] |
line diff
1.1 --- a/src/android/MainActivity.java Fri Oct 09 05:17:11 2015 +0300 1.2 +++ b/src/android/MainActivity.java Sat Oct 10 16:38:19 2015 +0300 1.3 @@ -25,7 +25,9 @@ 1.4 PopupWindow ad_win; 1.5 LinearLayout ad_layout, ad_main_layout; 1.6 boolean ad_ready = false; 1.7 - boolean waiting_for_ad = false; 1.8 + boolean ad_visible = false; 1.9 + boolean ad_show_pending = false; 1.10 + AdRequest ad_request; 1.11 1.12 @Override 1.13 protected void onCreate(Bundle saved_inst) 1.14 @@ -120,10 +122,11 @@ 1.15 1.16 act = this; 1.17 1.18 + /* 1.19 this.runOnUiThread(new Runnable() { 1.20 @Override 1.21 public void run() 1.22 - { 1.23 + {*/ 1.24 Log.i(tag, "[JAVA] Creating Ad popup"); 1.25 1.26 ad_win = new PopupWindow(act); 1.27 @@ -159,7 +162,6 @@ 1.28 Log.i(tag, "[JAVA] ad loaded"); 1.29 super.onAdLoaded(); 1.30 ad_ready = true; 1.31 - waiting_for_ad = false; 1.32 show_ad(); 1.33 } 1.34 @Override 1.35 @@ -168,18 +170,28 @@ 1.36 Log.e(tag, "[JAVA] ad failed to load, error code: " + error_code); 1.37 super.onAdFailedToLoad(error_code); 1.38 ad_ready = false; 1.39 - waiting_for_ad = false; 1.40 request_ad(); 1.41 } 1.42 }); 1.43 1.44 - if(!waiting_for_ad) { 1.45 + /*if(!ad_view.isLoading()) { 1.46 request_ad(); 1.47 - } 1.48 + }*/ 1.49 + AdRequest.Builder reqbuild = new AdRequest.Builder(); 1.50 + reqbuild.addTestDevice(AdRequest.DEVICE_ID_EMULATOR); 1.51 + reqbuild.addTestDevice(dev_id_gnexus); 1.52 + reqbuild.addTestDevice(dev_id_nexus7); 1.53 + ad_request = reqbuild.build(); 1.54 + 1.55 + ad_win.showAtLocation(ad_main_layout, Gravity.TOP, 0, 0); 1.56 + ad_win.update(); 1.57 + 1.58 + show_ad(); 1.59 1.60 Log.i(tag, "[JAVA] Done creating ad popup"); 1.61 + /* 1.62 } 1.63 - }); 1.64 + });*/ 1.65 } 1.66 1.67 public void destroy_ad_popup() 1.68 @@ -210,36 +222,54 @@ 1.69 reqbuild.addTestDevice(dev_id_gnexus); 1.70 reqbuild.addTestDevice(dev_id_nexus7); 1.71 ad_view.loadAd(reqbuild.build()); 1.72 - 1.73 - waiting_for_ad = true; 1.74 } 1.75 1.76 private void show_ad() 1.77 { 1.78 + Log.i(tag, "[JAVA] show_ad called"); 1.79 + if(ad_view == null || ad_request == null) { 1.80 + ad_show_pending = true; 1.81 + return; 1.82 + } 1.83 + /*if(!ad_visible) { 1.84 + ad_view.resume(); 1.85 + }*/ 1.86 + if(!ad_ready && !ad_view.isLoading()) { 1.87 + ad_view.loadAd(ad_request); 1.88 + return; 1.89 + } 1.90 + ad_view.setVisibility(View.VISIBLE); 1.91 + ad_view.resume(); 1.92 + ad_win.update(); 1.93 + ad_show_pending = false; 1.94 + /* 1.95 if(ad_ready) { 1.96 Log.i(tag, "[JAVA] show_ad called with ad ready"); 1.97 - ad_view.setVisibility(View.VISIBLE); 1.98 ad_win.showAtLocation(ad_main_layout, Gravity.TOP, 0, 0); 1.99 ad_win.update(); 1.100 } else { 1.101 - if(!waiting_for_ad) { 1.102 + if(!ad_view.isLoading()) { 1.103 Log.i(tag, "[JAVA] show_ad called with ad neither ready nor pending"); 1.104 request_ad(); 1.105 } else { 1.106 Log.i(tag, "[JAVA] show_ad called with ad pending: nop"); 1.107 } 1.108 } 1.109 + */ 1.110 } 1.111 1.112 private void hide_ad() 1.113 { 1.114 Log.i(tag, "[JAVA] hide_ad called"); 1.115 - //ad_view.setVisibility(View.GONE); 1.116 - ad_win.dismiss(); 1.117 - //ad_win.update(); 1.118 + ad_view.destroy(); 1.119 + ad_view.setVisibility(View.GONE); 1.120 + ad_view.pause(); 1.121 + //ad_win.dismiss(); 1.122 + ad_win.update(); 1.123 //destroy_ad_popup(); 1.124 ad_ready = false; 1.125 - waiting_for_ad = false; 1.126 + ad_visible = false; 1.127 + ad_show_pending = false; 1.128 } 1.129 1.130