Android啟動屏實現(xiàn)左右滑動切換查看功能
本文介紹一個app最常見的特性,就是新功能屬性介紹和啟動屏,一般會怎么實現(xiàn)呢,這不就打算告訴大家了么。
先說邏輯
- 先判斷是否第一次啟動app,如果是,則進入功能使用導(dǎo)航(最簡單的做法就是,左右滑動切換查看,滑動到最后一頁點擊按鈕進入首頁)。
- 如果不是,則顯示啟動屏,2秒之后進入首頁。
邏輯是很簡單,如果有廣告怎么辦?廣告肯定是從服務(wù)器拿,但會緩存到本地,沒網(wǎng)的時候可以顯示,可以使用webView來顯示廣告,反正筆者是這樣干,具體實現(xiàn)先不說。
看看效果

上代碼
SplashActivity.java
package com.devilwwj.featureguide;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import com.devilwwj.featureguide.global.AppConstants;
import com.devilwwj.featureguide.utils.SpUtils;
public class SplashActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// 判斷是否是第一次開啟應(yīng)用
boolean isFirstOpen = SpUtils.getBoolean(this, AppConstants.FIRST_OPEN);
// 如果是第一次啟動,則先進入功能引導(dǎo)頁
if (!isFirstOpen) {
Intent intent = new Intent(this, WelcomeGuideActivity.class);
startActivity(intent);
finish();
return;
}
// 如果不是第一次啟動app,則正常顯示啟動屏
setContentView(R.layout.activity_splash);
new Handler().postDelayed(new Runnable() {
@Override
public void run() {
enterHomeActivity();
}
}, 2000);
}
private void enterHomeActivity() {
Intent intent = new Intent(this, MainActivity.class);
startActivity(intent);
finish();
}
}
代碼解析:使用SharedPreference來保存app啟動狀態(tài),如果為true,則進入功能導(dǎo)航,否則延遲2秒之后進入主頁面。
WelcomeGuideActivity.java
package com.devilwwj.featureguide;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.LinearLayout;
import com.devilwwj.featureguide.global.AppConstants;
import com.devilwwj.featureguide.utils.SpUtils;
import java.util.ArrayList;
import java.util.List;
public class WelcomeGuideActivity extends Activity implements OnClickListener {
private ViewPager vp;
private GuideViewPagerAdapter adapter;
private List<View> views;
private Button startBtn;
// 引導(dǎo)頁圖片資源
private static final int[] pics = { R.layout.guid_view1,
R.layout.guid_view2, R.layout.guid_view3, R.layout.guid_view4 };
// 底部小點圖片
private ImageView[] dots;
// 記錄當(dāng)前選中位置
private int currentIndex;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_guide);
views = new ArrayList<View>();
// 初始化引導(dǎo)頁視圖列表
for (int i = 0; i < pics.length; i++) {
View view = LayoutInflater.from(this).inflate(pics[i], null);
if (i == pics.length - 1) {
startBtn = (Button) view.findViewById(R.id.btn_login);
startBtn.setTag("enter");
startBtn.setOnClickListener(this);
}
views.add(view);
}
vp = (ViewPager) findViewById(R.id.vp_guide);
// 初始化adapter
adapter = new GuideViewPagerAdapter(views);
vp.setAdapter(adapter);
vp.setOnPageChangeListener(new PageChangeListener());
initDots();
}
@Override
protected void onResume() {
super.onResume();
}
@Override
protected void onPause() {
super.onPause();
// 如果切換到后臺,就設(shè)置下次不進入功能引導(dǎo)頁
SpUtils.putBoolean(WelcomeGuideActivity.this, AppConstants.FIRST_OPEN, true);
finish();
}
@Override
protected void onStop() {
super.onStop();
}
@Override
protected void onDestroy() {
super.onDestroy();
}
private void initDots() {
LinearLayout ll = (LinearLayout) findViewById(R.id.ll);
dots = new ImageView[pics.length];
// 循環(huán)取得小點圖片
for (int i = 0; i < pics.length; i++) {
// 得到一個LinearLayout下面的每一個子元素
dots[i] = (ImageView) ll.getChildAt(i);
dots[i].setEnabled(false);// 都設(shè)為灰色
dots[i].setOnClickListener(this);
dots[i].setTag(i);// 設(shè)置位置tag,方便取出與當(dāng)前位置對應(yīng)
}
currentIndex = 0;
dots[currentIndex].setEnabled(true); // 設(shè)置為白色,即選中狀態(tài)
}
/**
* 設(shè)置當(dāng)前view
*
* @param position
*/
private void setCurView(int position) {
if (position < 0 || position >= pics.length) {
return;
}
vp.setCurrentItem(position);
}
/**
* 設(shè)置當(dāng)前指示點
*
* @param position
*/
private void setCurDot(int position) {
if (position < 0 || position > pics.length || currentIndex == position) {
return;
}
dots[position].setEnabled(true);
dots[currentIndex].setEnabled(false);
currentIndex = position;
}
@Override
public void onClick(View v) {
if (v.getTag().equals("enter")) {
enterMainActivity();
return;
}
int position = (Integer) v.getTag();
setCurView(position);
setCurDot(position);
}
private void enterMainActivity() {
Intent intent = new Intent(WelcomeGuideActivity.this,
SplashActivity.class);
startActivity(intent);
SpUtils.putBoolean(WelcomeGuideActivity.this, AppConstants.FIRST_OPEN, true);
finish();
}
private class PageChangeListener implements OnPageChangeListener {
// 當(dāng)滑動狀態(tài)改變時調(diào)用
@Override
public void onPageScrollStateChanged(int position) {
// arg0 ==1的時辰默示正在滑動,arg0==2的時辰默示滑動完畢了,arg0==0的時辰默示什么都沒做。
}
// 當(dāng)前頁面被滑動時調(diào)用
@Override
public void onPageScrolled(int position, float arg1, int arg2) {
// arg0 :當(dāng)前頁面,及你點擊滑動的頁面
// arg1:當(dāng)前頁面偏移的百分比
// arg2:當(dāng)前頁面偏移的像素位置
}
// 當(dāng)新的頁面被選中時調(diào)用
@Override
public void onPageSelected(int position) {
// 設(shè)置底部小點選中狀態(tài)
setCurDot(position);
}
}
}
代碼解析:左右滑動是使用ViewPager來做的,切換4個不同的View,監(jiān)聽ViewPager的頁面切換事件來更改底部指示點的切換,滑動到最后一個頁面,設(shè)置按鈕的點擊事件,點擊進入首頁。
以上就是本文的全部內(nèi)容,希望對大家學(xué)習(xí)Android軟件編程有所幫助。
相關(guān)文章
flutter監(jiān)聽app進入前后臺狀態(tài)的實現(xiàn)
在開發(fā)app的過程中,我們經(jīng)常需要知道app處于前后臺的狀態(tài),本文主要介紹了flutter監(jiān)聽app進入前后臺狀態(tài)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
android實現(xiàn)常駐通知欄遇到的問題及解決辦法
這篇文章主要介紹了android實現(xiàn)常駐通知欄遇到的問題及解決辦法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06
詳解Android Scroller與computeScroll的調(diào)用機制關(guān)系
這篇文章主要介紹了詳解Android Scroller與computeScroll的調(diào)用機制關(guān)系的相關(guān)資料,需要的朋友可以參考下2016-01-01
Android實現(xiàn)視頻播放--騰訊瀏覽服務(wù)(TBS)功能
TBS視頻播放器可以支持市面上幾乎所有的視頻格式,包括mp4, flv, avi, 3gp, webm, ts, ogv, m3u8, asf, wmv, rm, rmvb, mov, mkv等18種視頻格式。這篇文章主要介紹了Android實現(xiàn)視頻播放--騰訊瀏覽服務(wù)(TBS),需要的朋友可以參考下2018-07-07

