国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

Android開發之splash界面下詳解及實例

2019-12-12 03:24:51
字體:
來源:轉載
供稿:網友

現在剛下載的很多APP應用第一次打開都會在進入主界面之前有導航頁,用來展示公司logo,或者推廣自身這款APP。先上效果圖:
這里寫圖片描述
這里寫圖片描述
這里寫圖片描述

首先解釋一下:支持進入首頁只能往右滑動,中間可以左右滑動,最后一張只能向前滑動,點擊立即體驗會進入主界面,點擊跳過也會進入到主界面。接下來上代碼。

1,在app/build.gradle中的閉包中加入:

compile 'cn.bingoogolapple:bga-banner:2.1.6@aar'compile 'com.android.support:support-v4:24.1.0'

2,布局文件:activity_splash.xml。

<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  xmlns:app="http://schemas.android.com/apk/res-auto"  xmlns:tools="http://schemas.android.com/tools"  android:id="@+id/activity_splash"  android:layout_width="match_parent"  android:layout_height="match_parent"  tools:context="com.gyq.cloudreader.SplashActivity">  <cn.bingoogolapple.bgabanner.BGAGuideLinkageLayout style="@style/MatchMatch">    <cn.bingoogolapple.bgabanner.BGABanner      android:id="@+id/banner_guide_background"      style="@style/MatchMatch"      app:banner_pageChangeDuration="1000"      app:banner_pointAutoPlayAble="false"      app:banner_pointContainerBackground="@android:color/transparent"      app:banner_pointDrawable="@drawable/bga_banner_selector_point_hollow"      app:banner_pointTopBottomMargin="15dp"      app:banner_transitionEffect="fade"/>    <cn.bingoogolapple.bgabanner.BGABanner      android:id="@+id/banner_guide_foreground"      style="@style/MatchMatch"      app:banner_pageChangeDuration="1000"      app:banner_pointAutoPlayAble="false"      app:banner_pointContainerBackground="@android:color/transparent"      app:banner_pointDrawable="@drawable/bga_banner_selector_point_hollow"      app:banner_pointTopBottomMargin="15dp"      app:banner_transitionEffect="alpha"/>  </cn.bingoogolapple.bgabanner.BGAGuideLinkageLayout>  <TextView    android:id="@+id/tv_guide_skip"    style="@style/WrapWrap"    android:layout_alignParentRight="true"    android:layout_marginRight="8dp"    android:layout_marginTop="8dp"    android:clickable="true"    android:padding="4dp"    android:text="跳過 >"    android:textColor="@android:color/white"    android:textSize="16sp"/>  <Button    android:id="@+id/btn_guide_enter"    style="@style/WrapWrap"    android:layout_alignParentBottom="true"    android:layout_centerHorizontal="true"    android:layout_marginBottom="60dp"    android:background="@drawable/selector_btn_test"    android:padding="10dp"    android:text="立即體驗"    android:textColor="@android:color/white"    android:textSize="20sp"    android:visibility="gone"    tools:visibility="visible"/></RelativeLayout>

3,邏輯代碼,SplashActivity.java

package com.gyq.cloudreader;import android.content.Intent;import android.os.Bundle;import android.support.v7.app.AppCompatActivity;import cn.bingoogolapple.bgabanner.BGABanner;/** * 引導界面 */public class SplashActivity extends AppCompatActivity {  private BGABanner mBackgroundBanner;  private BGABanner mForegroundBanner;  @Override  protected void onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    setContentView(R.layout.activity_splash);    initView();    initListener();    processLogic();  }  private void initView() {    mBackgroundBanner = (BGABanner)findViewById(R.id.banner_guide_background);    mForegroundBanner = (BGABanner)findViewById(R.id.banner_guide_foreground);  }  private void initListener() {    mForegroundBanner.setEnterSkipViewIdAndDelegate(R.id.btn_guide_enter, R.id.tv_guide_skip, new BGABanner.GuideDelegate() {      @Override      public void onClickEnterOrSkip() {        startActivity(new Intent(SplashActivity.this, MainActivity.class));        finish();      }    });  }  private void processLogic() {    //設置數據源    mBackgroundBanner.setData(R.drawable.uoko_guide_background_1,R.drawable.uoko_guide_background_2,R.drawable.uoko_guide_background_3);    mForegroundBanner.setData(R.drawable.uoko_guide_foreground_1,R.drawable.uoko_guide_foreground_2,R.drawable.uoko_guide_foreground_3);  }  @Override  protected void onResume() {    super.onResume();    // 如果開發者的引導頁主題是透明的,需要在界面可見時給背景 Banner 設置一個白色背景,避免滑動過程中兩個 Banner 都設置透明度后能看到 Launcher    mBackgroundBanner.setBackgroundResource(android.R.color.white);  }}

小結:記得以前寫一個這樣的引導頁,還需要自己手寫半天,現在有開源啦!看上面的代碼我想你應該已經知道了這個就是用的BGABanner來實現的。不過還有點小細節。

1,布局文件中的style=”@style/WrapWrap”,我們需要在values文件夾下新建一個styles_base.xml。

<?xml version="1.0" encoding="utf-8"?><resources xmlns:android="http://schemas.android.com/apk/res/android">  <style name="WrapMatch">    <item name="android:layout_width">wrap_content</item>    <item name="android:layout_height">match_parent</item>  </style>  <style name="MatchWrap">    <item name="android:layout_width">match_parent</item>    <item name="android:layout_height">wrap_content</item>  </style>  <style name="WrapWrap">    <item name="android:layout_width">wrap_content</item>    <item name="android:layout_height">wrap_content</item>  </style>  <style name="MatchMatch">    <item name="android:layout_width">match_parent</item>    <item name="android:layout_height">match_parent</item>  </style>  <style name="MatchAuto">    <item name="android:layout_width">match_parent</item>    <item name="android:layout_weight">1</item>    <item name="android:layout_height">0dp</item>  </style>  <style name="AutoMatch">    <item name="android:layout_width">0dp</item>    <item name="android:layout_weight">1</item>    <item name="android:layout_height">match_parent</item>  </style>  <style name="WrapAuto">    <item name="android:layout_width">wrap_content</item>    <item name="android:layout_weight">1</item>    <item name="android:layout_height">0dp</item>  </style>  <style name="AutoWrap">    <item name="android:layout_width">0dp</item>    <item name="android:layout_weight">1</item>    <item name="android:layout_height">wrap_content</item>  </style>  <style name="WrapMatch.Vertical">    <item name="android:orientation">vertical</item>  </style>  <style name="WrapMatch.Horizontal">    <item name="android:orientation">horizontal</item>  </style>  <style name="MatchWrap.Vertical">    <item name="android:orientation">vertical</item>  </style>  <style name="MatchWrap.Horizontal">    <item name="android:orientation">horizontal</item>  </style>  <style name="WrapWrap.Vertical">    <item name="android:orientation">vertical</item>  </style>  <style name="WrapWrap.Horizontal">    <item name="android:orientation">horizontal</item>  </style>  <style name="MatchMatch.Vertical">    <item name="android:orientation">vertical</item>  </style>  <style name="MatchMatch.Horizontal">    <item name="android:orientation">horizontal</item>  </style>  <style name="MatchAuto.Vertical">    <item name="android:orientation">vertical</item>  </style>  <style name="MatchAuto.Horizontal">    <item name="android:orientation">horizontal</item>  </style>  <style name="AutoMatch.Vertical">    <item name="android:orientation">vertical</item>  </style>  <style name="AutoMatch.Horizontal">    <item name="android:orientation">horizontal</item>  </style>  <style name="WrapAuto.Vertical">    <item name="android:orientation">vertical</item>  </style>  <style name="WrapAuto.Horizontal">    <item name="android:orientation">horizontal</item>  </style>  <style name="AutoWrap.Vertical">    <item name="android:orientation">vertical</item>  </style>  <style name="AutoWrap.Horizontal">    <item name="android:orientation">horizontal</item>  </style>  <style name="MatchOne">    <item name="android:layout_width">match_parent</item>    <item name="android:layout_height">1px</item>  </style>  <style name="OneMatch">    <item name="android:layout_width">1px</item>    <item name="android:layout_height">match_parent</item>  </style></resources>

還有styles.xml文件中添加如下代碼,這樣可以整個屏幕顯示:

<resources>  <!-- Base application theme. -->  <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">    <!-- Customize your theme here. -->    <item name="colorPrimary">@color/colorPrimary</item>    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>    <item name="colorAccent">@color/colorAccent</item>  </style>  <!--避免第一次進來白屏或黑屏-->  <style name="AppTheme.Splash">    <item name="windowActionBar">false</item>    <item name="windowNoTitle">true</item>    <item name="android:windowBackground">@android:color/transparent</item>    <item name="android:colorBackgroundCacheHint">@null</item>    <item name="android:windowIsTranslucent">true</item>    <item name="android:windowFullscreen">true</item>    <item name="android:windowContentOverlay">@null</item>  </style></resources>

最后清單文件,注冊SplashActivity是寫如下代碼。

<activity android:name=".SplashActivity"      android:label="@string/app_name"      android:screenOrientation="portrait"      android:theme="@style/AppTheme.Splash">      <intent-filter>        <action android:name="android.intent.action.MAIN" />        <category android:name="android.intent.category.LAUNCHER" />      </intent-filter>    </activity>

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 海南省| 定陶县| 剑阁县| 乐业县| 芒康县| 青河县| 论坛| 泰顺县| 鄂伦春自治旗| 唐海县| 尼玛县| 武强县| 沁阳市| 大竹县| 临潭县| 吉木萨尔县| 甘南县| 峨边| 博乐市| 蛟河市| 长白| 项城市| 洪江市| 沁阳市| 奎屯市| 芜湖县| 搜索| 静乐县| 来宾市| 唐海县| 观塘区| 阿瓦提县| 大田县| 江西省| 湟中县| 屏东市| 新郑市| 肥西县| 仪征市| 大渡口区| 五大连池市|