android啟動頁設計專題及常見問題 - CSDN

2021-01-07 CSDN技術社區

轉載請註明出處:http://blog.csdn.net/wangjihuanghun/article/details/63255144

啟動頁幾乎成為了每個app的標配,有些商家在啟動頁中增加了開屏廣告以此帶來更多的收入。目前啟動頁的廣告都有倒計時的功能,那麼我們在倒計時的過程中能做些什麼呢?

這篇文章主要包括以下兩方面內容

集成騰訊廣告聯盟的SDK 啟動頁加載過程中,後臺初始化數據

我們在設計啟動頁時的常規做法是建立一個Activity來加載開屏圖片或者廣告,作為程序的入口,那麼在這個三到五秒時間內如果進行數據下載,當用戶點擊了跳過按鈕或者計時結束了數據還沒初始化完成,已經進入了主頁面,而主界面剛好需要那些基礎數據該如何?

因此,我們將啟動頁和主界面設計成兩個Fragment,集成到MainActivity中。這樣我們在啟動頁中加載廣告,在主界面中下載數據,登陸等耗時操作,程序的結構如下:

01 activity_main.xml

<?xml version="1.0" encoding="utf-8"?><FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.landptf.blog.MainActivity"> <fragment android:id="@+id/fm_splash" android:layout_width="match_parent" android:layout_height="match_parent" class="com.landptf.blog.splash.SplashFragment" /> <fragment android:id="@+id/fm_main" android:layout_width="match_parent" android:layout_height="match_parent" class="com.landptf.blog.MainFragment" /></FrameLayout>

包含了兩個fragment,分別是加載廣告也和主界面的

02 MainActivity.java

/** * Created by landptf on 2017/03/18. * 主頁面,包含了SplashFragment和MainFragment */public class MainActivity extends AppCompatActivity { private FragmentManager frManager; private SplashFragment fmSplash; private MainFragment fmMain; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); } private void initView() { frManager = getSupportFragmentManager(); fmSplash = (SplashFragment) frManager.findFragmentById(R.id.fm_splash); fmMain = (MainFragment) frManager.findFragmentById(R.id.fm_main); showSplash(); } private void showSplash(){ frManager.beginTransaction().hide(fmMain).show(fmSplash).commit(); } public void dismissSplash(){ frManager.beginTransaction().hide(fmSplash).show(fmMain).commitAllowingStateLoss(); }}

在SplashFragment中廣告加載完成或者點擊跳過後調用dismissSplash將SplashFragment隱藏,將MainFragment顯示出來

03 SplashFragment.java

/** * Created by landptf on 2017/03/18. * 啟動頁,集成了騰訊廣告聯盟的開屏廣告 */public class SplashFragment extends Fragment { private static final String TAG = SplashFragment.class.getSimpleName(); private MainActivity activity; private ViewGroup container; private TextView tvSkip; private ImageView ivSplashHolder; private static final String SKIP_TEXT = "點擊跳過 %d"; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { return inflater.inflate(R.layout.fragment_splash, container, false); } @Override public void onActivityCreated(@Nullable Bundle savedInstanceState) { super.onActivityCreated(savedInstanceState); activity = (MainActivity) getActivity(); initView(); } private void initView() { container = (ViewGroup) activity.findViewById(R.id.fl_splash_container); tvSkip = (TextView) activity.findViewById(R.id.tv_skip); ivSplashHolder = (ImageView) activity.findViewById(R.id.iv_splash_holder); ApplyPermissions(); } /** * 動態申請集成騰訊廣告聯盟的開屏廣告所需要的三個權限 * 使用了RxPermissions開源框架 */ private void ApplyPermissions() { RxPermissions rxPermissions = new RxPermissions(activity); rxPermissions .request(Manifest.permission.READ_PHONE_STATE, Manifest.permission.ACCESS_COARSE_LOCATION, Manifest.permission.WRITE_EXTERNAL_STORAGE) .subscribe(granted -> { if (granted) { new SplashAD(activity, container, tvSkip, Constants.APPID, Constants.SplashPosID, adListener, 5000); } else { activity.dismissSplash(); } }); } /** * 開屏廣告狀態的監聽 */ private SplashADListener adListener = new SplashADListener() { /** * 廣告關閉時調用,可能是用戶關閉或者展示時間到。此時一般需要跳過開屏的Activity,進入應用內容頁面 */ @Override public void onADDismissed() { activity.dismissSplash(); } /** * 廣告加載失敗,errCode用於描述失敗原因。 * @param i */ @Override public void onNoAD(int i) { Log.e(TAG, "error code = " + i); activity.dismissSplash(); } /** * 廣告成功展示時調用 */ @Override public void onADPresent() { ivSplashHolder.setVisibility(View.GONE); } /** * 廣告被點擊時調用 */ @Override public void onADClicked() { Log.i(TAG, "SplashADClicked"); } /** * 倒計時回調,返回廣告還將被展示的剩餘時間,單位是ms * @param l */ @Override public void onADTick(long l) { tvSkip.setText(String.format(SKIP_TEXT, Math.round(l / 1000f))); } };}

這裡集成了騰訊廣告聯盟,點擊這裡註冊,流程比較簡單,按照說明一步一步進行就可以了,sdk文檔也比較詳細。

當廣告加載完成後調用 activity.dismissSplash();將其隱藏

04 MainFragment.java

/** * 模擬後臺耗時操作 */private void testThread(){ new Thread(() -> { int i = 0; while (i < 5) { try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } Log.e(TAG, "--- " + i + " ---"); i++; } }).start();}

在MainFragment主線程中開啟了一個只線程來模擬耗時操作,通過log可以看到在廣告倒計時的過程中線程已經在執行了。

03-18 03:30:50.348 9491-9513/com.landptf.blog E/MainFragment: --- 0 ---03-18 03:30:51.348 9491-9513/com.landptf.blog E/MainFragment: --- 1 ---03-18 03:30:52.348 9491-9513/com.landptf.blog E/MainFragment: --- 2 ---03-18 03:30:53.349 9491-9513/com.landptf.blog E/MainFragment: --- 3 ---03-18 03:30:54.350 9491-9513/com.landptf.blog E/MainFragment: --- 4 ---

以上就是app的啟動頁方案,充分利用了加載廣告的時間

全部代碼已上傳至Github,歡迎訪問

end.

相關焦點

  • android 從後臺啟動頁面專題及常見問題 - CSDN
    這三個Tesseract語言包合起來約有70M左右,APK文件中拷貝語言包到手機存儲中需要幾秒時間,所以我們做了一個啟動頁面,在為用戶展示App第一印象的同時,後臺拷貝這三個語言包。經過比較,知乎日報的啟動頁面有從中心點展開逼進用戶的效果,我們決定利用此效果來設計啟動頁面。最終效果如圖所示:
  • android 服務啟動後專題及常見問題 - CSDN
    Launcher啟動流程1、AMS的systemReady()上回講述了《Android系統啟動流程》,當系統在Framework層經過一系列多種語言程序有來有回之後,系統服務會被其中,其中包括AMS,startOtherServices()方法執行後階段,各種被啟動起來的
  • android 首次打開判斷專題及常見問題 - CSDN
    前言用真機運行appium代碼,首次打開app有的手機會出現權限彈窗問題,一般這種彈窗都是在引導頁前面或者引導頁後面出現。權限彈窗上面的按鈕都是固定的,只需要定位到「始終允許」按鈕,點擊確定就可以了。還有一個問題是這種彈窗的個數不確定,有的app是2個有的是3個,為了解決這個問題,可以專門寫個判斷方法。
  • android 不同大小的屏幕專題及常見問題 - CSDN
    轉載請註明出處:http://blog.csdn.net/guolin_blog/article/details/8830286原文地址為:http://developer.android.com/training/multiscreen/screensizes.html
  • android布局詳解專題及常見問題 - CSDN
    <include android:id=」@+id/cell3 layout=」@layout/workspace_screen」 /></LinearLayout>  上面的代碼中的<include>標籤還使用了一個android:id屬性,實際上,該屬性指定的是workspace_screen.xml布局文件中的根節點的android
  • android app被殺原因專題及常見問題 - CSDN
    分析長按HOME鍵清理App最終會執行到ActivityManagerService.cleanUpRemovedTaskLocked方法中,ActivityManagerService類在文件"frameworks/base/services/core/java/com/android/server/am/ActivityManagerService.java"中,
  • android tv放大專題及常見問題 - CSDN
    ;import android.os.Bundle;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.view.WindowManager;import android.widget.BaseAdapter;import android.widget.ImageView
  • android 復用 布局優化專題及常見問題 - CSDN
    1、布局重用<include /> <include />標籤能夠重用布局文件,簡單的使用如下:     <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"           android:orientation
  • android 進度條顯示時間專題及常見問題 - CSDN
    定義一個attrs.xml自定義CircleProgressViewpackage com.sample.circleprogressview.widget;import android.animation.ValueAnimator;import android.content.Context
  • android通過代碼實現的多布局專題及常見問題 - CSDN
    但是這樣就遇到了很多問題。 首先是SeekBar設置setProgressDrawable問題。因為我們的是視頻播放器,所以這個SeekBar需要有背景、緩衝進度和播放進度,最好的方法就是用layer-list 的xml布局實現,類似這樣:<?xml version="1.0" encoding="utf-8"?
  • android中實例化類專題及常見問題 - CSDN
    轉自:http://www.android123.com.cn/androidkaifa/687.html三、在JNI中構造和實例化Java類 public class AndroidJniDemo4{ public static native
  • android藍牙框架專題及常見問題 - CSDN
    代碼來源於Android P,本文相關代碼:client:frameworks/base/core/java/android/bluetooth/*system/bt/binder/android/bluetooth/**.aidlservie:framework/base/services/core/java/com/android/server
  • 商品資料庫設計 電商系統專題及常見問題 - CSDN
    在電商系統中,商品模型至關重要,是整個電商的核心,下面通過一個簡單的分析,設計一個基礎的商品模型。商品模型的演化在以前,那時 CMS 很流行,最常見的模型是欄目 – 文章模型。於是做電商的時候,自然就繼承了這種一對多的關係。只是欄目變成了分類,文章變成了商品。商品也具備了獨特的業務屬性。
  • android藍牙相關框架專題及常見問題 - CSDN
    代碼來源於Android P,本文相關代碼:client:frameworks/base/core/java/android/bluetooth/*system/bt/binder/android/bluetooth/**.aidlservie:framework/base/services/core/java/com/android/server/BluetoothService.java
  • android關閉開機啟動 - CSDN
    1000); } mPolicy.systemBooted(); performEnableScreen(); }  這裡會將mSystemBooted設置為true,然後在hideBootMessagesLocked方法裡面把mShowingBootMessages true改成false,然後設定一個強制的30s啟動超時
  • android 自定義view大小專題及常見問題 - CSDN
    它本質上是一個FrameLayoutViewRoot在Activtiy啟動時創建,負責管理、布局、渲染窗口UI等等對於多View的視圖,結構是樹形結構:最頂層是ViewGroup,ViewGroup下可能有多個ViewGroup或View,如下圖:一定要記住:無論是measure過程、layout過程還是draw過程,永遠都是從View
  • android中的啟動模式 - CSDN
    在Android中Activity的啟動模式決定了Activity的啟動運行方式。   Android總Activity的啟動模式分為四種: Activity啟動模式設置: <activity android:name=".MainActivity" android:launchMode="standard" />Activity的四種啟動模式: 1. standard 模式啟動模式,
  • android audio 焦點專題及常見問題 - CSDN
    我們android系統裡面會安裝各種多媒體軟體,如果不制定一個有效合理的規則,各個應用各自為政,那麼可能就會出現各種播放器、軟體的混音。音頻焦點機制規定某一時刻只能有一個應用獲取到聲音的焦點,這個時候就可以發出聲音。當然,在這個應用獲取到焦點之前,需要通知其他所用的應用失去焦點。
  • androidaudio焦點專題及常見問題 - CSDN
    我們android系統裡面會安裝各種多媒體軟體,如果不制定一個有效合理的規則,各個應用各自為政,那麼可能就會出現各種播放器、軟體的混音。音頻焦點機制規定某一時刻只能有一個應用獲取到聲音的焦點,這個時候就可以發出聲音。當然,在這個應用獲取到焦點之前,需要通知其他所用的應用失去焦點。
  • android 前攝像頭對焦專題及常見問題 - CSDN
    * * Rotate, scale and translate touch rectangle using matrix configured in* {@link SurfaceHolder.Callback#surfaceChanged(android.view.SurfaceHolder, int, int, int)}*/