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

首頁 > 系統 > Android > 正文

Android UI設計與開發之實現應用程序只啟動一次引導界面

2019-10-22 18:28:53
字體:
來源:轉載
供稿:網友

這篇文章算是對整個引導界面開發專題的一個終結了吧,個人覺得大部分的引導界面基本上都是千篇一律的,只要熟練掌握了一個,基本上也就沒什么好說的了,要是在今后的開發中遇到了更好玩,更有趣的引導界面,博主也會在這里及時的跟大家分享,今天的內容主要是教大家的應用程序只有在第一次啟動的時候顯示引導界面,以后在啟動程序的時候就不再顯示了。

其實要想實現這樣的效果,只要使用SharedPreferences類,就會讓程序變的非常簡單,下面來詳細介紹一下這個類的使用方法

一、SharedPreferences的詳細介紹和用法

SharedPreferences介紹:

做軟件開發應該都知道,很多軟件會有配置文件,里面存放這程序運行當中的各個屬性值,由于其配置信息并不多,如果采用數據庫來存放并不劃算,因為數據庫連接跟操作等耗時大大影響了程序的效率,因此我們使用鍵值這種一一對應的關系來存放這些配置信息。SharedPreferences正是Android中用于實現這中存儲方式的技術。

SharedPreferences的使用非常簡單,能夠輕松的存放數據和讀取數據。SharedPreferences只能保存簡單類型的數據,例如,String、int等。一般會將復雜類型的數據轉換成Base64編碼,然后將轉換后的數據以字符串的形式保存在 XML文件中,再用SharedPreferences保存。

SharedPreferences使用方法:

<1> 使用Activity類的getSharedPreferences方法獲得SharedPreferences對象,其中存儲key-value的文件的名稱由getSharedPreferences方法的第一個參數指定;
<2> 使用SharedPreferences接口的edit獲得SharedPreferences.Editor對象;
<3> 通過SharedPreferences.Editor接口的putXxx方法保存key-value對。其中Xxx表示不同的數據類型。例如:字符串類型的value需要用putString方法;
<4> 通過SharedPreferences.Editor接口的commit方法保存key-value對。commit方法相當于數據庫事務中的提交(commit)操作。

具體代碼的書寫流程為:

A、存放數據信息

<1> 打開Preferences,名稱為setting,如果存在則打開它,否則創建新的Preferences
         SharedPreferences settings = getSharedPreferences(“setting”, 0);
<2> 讓setting處于編輯狀態
         SharedPreferences.Editor editor = settings.edit();
<3> 存放數據
         editor.putString(“name”,”ATAAW”);
         editor.putString(“URL”,”ATAAW.COM”);
<4> 完成提交
         editor.commit();

B、讀取數據信息

<1> 獲取Preferences
         SharedPreferences settings = getSharedPreferences(“setting”, 0);
<2> 取出數據
         String name = settings.getString(“name”,”默認值”);
         String url = setting.getString(“URL”,”default”);

       以上就是SharedPreferences的使用方法,其中創建的Preferences文件存放位置可以在Eclipse中查看:
DDMS->File Explorer /<package name>/shared_prefs/setting.xml

二、實現的效果圖

第一次啟動程序:歡迎界面-->引導界面-->主頁面

以后啟動程序:啟動頁-->系統主頁

第一次啟動時的效果圖

歡迎界面:

 Android,UI只啟動一次引導界面,UI引導界面,Android啟動一次引導界面

引導界面效果圖1:

Android,UI只啟動一次引導界面,UI引導界面,Android啟動一次引導界面

引導界面效果圖2:

Android,UI只啟動一次引導界面,UI引導界面,Android啟動一次引導界面

進入主頁面:

Android,UI只啟動一次引導界面,UI引導界面,Android啟動一次引導界面

以后啟動程序的效果圖

歡迎界面:

Android,UI只啟動一次引導界面,UI引導界面,Android啟動一次引導界面

程序主頁面:

Android,UI只啟動一次引導界面,UI引導界面,Android啟動一次引導界面

三、程序的目錄結構

Android,UI只啟動一次引導界面,UI引導界面,Android啟動一次引導界面

四、具體的實現編碼

1、  在引導布局界面中加入ViewPager組件,activity_guide.xml:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  xmlns:tools="http://schemas.android.com/tools"  android:layout_width="wrap_content"  android:layout_height="wrap_content" >   <android.support.v4.view.ViewPager   android:id="@+id/viewpager"   android:layout_width="fill_parent"   android:layout_height="fill_parent" /> </RelativeLayout> 

2、接著在guide_view01.xml等幾個布局頁面中添加引導界面要顯示的圖片和控件,因為這幾個布局界面都大同小異,所以在這里我就不一一貼出來了吧,有需要的同學可以直接下載源碼,guide_view01.xml:

<?xml version="1.0" encoding="UTF-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  android:layout_width="fill_parent"  android:layout_height="fill_parent"  android:background="@drawable/star_img1"  android:orientation="vertical" > </RelativeLayout> 

3、然后是歡迎界面的布局界面,activity_welcome:

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  android:layout_width="fill_parent"  android:layout_height="fill_parent"  android:orientation="vertical"  android:background="@drawable/welcome_background"> </LinearLayout> 

4、最后是主界面的布局,activity_main:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  xmlns:tools="http://schemas.android.com/tools"  android:layout_width="wrap_content"  android:layout_height="wrap_content" >   <TextView   android:id="@+id/textView1"   android:layout_width="wrap_content"   android:layout_height="wrap_content"   android:layout_alignParentLeft="true"   android:layout_alignParentTop="true"   android:text="歡迎來到主頁面!"   android:textSize="25sp"/> </RelativeLayout> 

5、在這里還要創建一個xml文件來實現自定義按鈕的效果,關于自定義按鈕的效果實現我會在后面的文章中專題詳細介紹,這里就不在贅述start_btn.xml:

<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android">  <item android:state_enabled="true" android:state_pressed="true"   android:drawable="@drawable/login_button_select" /> <!--按下時的效果-->      <item android:state_enabled="true" android:drawable="@drawable/login_button" /> <!--正常狀態的效果--> </selector> 

6、布局界面已經講解完畢,接下來讓我們進行詳細的代碼講解,ViewPager適配器代碼,ViewPagerAdapter.Java:

package com.yangyu.myguideview04;  import java.util.ArrayList;  import android.support.v4.view.PagerAdapter; import android.support.v4.view.ViewPager; import android.view.View;  /**  * @author yangyu  * 功能描述:ViewPager適配器,用來綁定數據和view  */ public class ViewPagerAdapter extends PagerAdapter {    //界面列表  private ArrayList<View> views;    public ViewPagerAdapter (ArrayList<View> views){   this.views = views;  }     /**   * 獲得當前界面數   */  @Override  public int getCount() {    if (views != null) {     return views.size();    }     return 0;  }   /**   * 初始化position位置的界面   */  @Override  public Object instantiateItem(View view, int position) {      ((ViewPager) view).addView(views.get(position), 0);      return views.get(position);  }    /**   * 判斷是否由對象生成界面   */  @Override  public boolean isViewFromObject(View view, Object arg1) {   return (view == arg1);  }   /**   * 銷毀position位置的界面   */  @Override  public void destroyItem(View view, int position, Object arg2) {   ((ViewPager) view).removeView(views.get(position));    } } 

7、引導界面Activity,GuideActivity.java:

package com.yangyu.myguideview04;  import java.util.ArrayList;  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;  /**  * @author yangyu  * 功能描述:引導界面activity類  */ public class GuideActivity extends Activity implements OnPageChangeListener{  // 定義ViewPager對象  private ViewPager viewPager;   // 定義ViewPager適配器  private ViewPagerAdapter vpAdapter;   // 定義一個ArrayList來存放View  private ArrayList<View> views;   // 定義各個界面View對象  private View view1, view2, view3, view4;    //定義開始按鈕對象  private Button startBt;     @Override  protected void onCreate(Bundle savedInstanceState) {   super.onCreate(savedInstanceState);   setContentView(R.layout.activity_guide);      initView();      initData();  }   /**   * 初始化組件   */  private void initView() {   //實例化各個界面的布局對象   LayoutInflater mLi = LayoutInflater.from(this);   view1 = mLi.inflate(R.layout.guide_view01, null);   view2 = mLi.inflate(R.layout.guide_view02, null);   view3 = mLi.inflate(R.layout.guide_view03, null);   view4 = mLi.inflate(R.layout.guide_view04, null);     // 實例化ViewPager   viewPager = (ViewPager) findViewById(R.id.viewpager);    // 實例化ArrayList對象   views = new ArrayList<View>();    // 實例化ViewPager適配器   vpAdapter = new ViewPagerAdapter(views);      //實例化開始按鈕   startBt = (Button) view4.findViewById(R.id.startBtn);  }   /**   * 初始化數據   */  private void initData() {   // 設置監聽   viewPager.setOnPageChangeListener(this);   // 設置適配器數據   viewPager.setAdapter(vpAdapter);    //將要分頁顯示的View裝入數組中    views.add(view1);   views.add(view2);   views.add(view3);   views.add(view4);              // 給開始按鈕設置監聽   startBt.setOnClickListener(new OnClickListener() {    @Override    public void onClick(View v) {      startbutton();    }   });  }   @Override  public void onPageScrollStateChanged(int arg0) {      }   @Override  public void onPageScrolled(int arg0, float arg1, int arg2) {     }   @Override  public void onPageSelected(int arg0) {     }    /**   * 相應按鈕點擊事件   */  private void startbutton() {   Intent intent = new Intent();   intent.setClass(GuideActivity.this,MainActivity.class);   startActivity(intent);   this.finish();   } } 

8、歡迎界面Activity,Welcome.java:

package com.yangyu.myguideview04;  import android.app.Activity; import android.content.Intent; import android.content.SharedPreferences; import android.content.SharedPreferences.Editor; import android.os.Bundle;  /**  * @author yangyu  * 功能描述:歡迎界面  */ public class Welcome extends Activity implements Runnable {    //是否是第一次使用  private boolean isFirstUse;    protected void onCreate(Bundle savedInstanceState) {   super.onCreate(savedInstanceState);   setContentView(R.layout.activity_welcome);   /**    * 啟動一個延遲線程    */   new Thread(this).start();  }   public void run() {   try {    /**     * 延遲兩秒時間     */    Thread.sleep(2000);        //讀取SharedPreferences中需要的數據    SharedPreferences preferences = getSharedPreferences("isFirstUse",MODE_WORLD_READABLE);     isFirstUse = preferences.getBoolean("isFirstUse", true);     /**     *如果用戶不是第一次使用則直接調轉到顯示界面,否則調轉到引導界面     */    if (isFirstUse) {     startActivity(new Intent(Welcome.this, GuideActivity.class));    } else {     startActivity(new Intent(Welcome.this, MainActivity.class));    }    finish();        //實例化Editor對象    Editor editor = preferences.edit();    //存入數據    editor.putBoolean("isFirstUse", false);    //提交修改    editor.commit();     } catch (InterruptedException e) {    }  } } 

在歡迎界面中使用了SharedPreferences來讀取用戶的信息,判斷是否是第一次使用程序,這里的isFirstUse可以根據讀者的需要換成任意類型,只要給它加一個判斷就行了

9、主界面Activity,這里就加載了一個簡單的布局文件,讀者可以根據需要對該類進行擴展,MainActivity.java:

package com.yangyu.myguideview04;  import android.app.Activity; import android.os.Bundle;  /**  * @author yangyu  * 功能描述:主程序入口類頁面  */ public class MainActivity extends Activity {   @Override  protected void onCreate(Bundle savedInstanceState) {   super.onCreate(savedInstanceState);   setContentView(R.layout.activity_main);  }   } 

引導界面的專題就告一段落了,接下來會以主頁面的UI設計為專題進行詳細的實戰講解,希望大家能繼續關注該系列文章。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 临颍县| 子长县| 兴国县| 金门县| 石家庄市| 松滋市| 永顺县| 黄山市| 绿春县| 泰和县| 榆中县| 平泉县| 兴隆县| 上虞市| 绥滨县| 东乌珠穆沁旗| 辽宁省| 宁晋县| 余庆县| 米泉市| 醴陵市| 遂平县| 南京市| 西乌| 惠水县| 福州市| 承德市| 金华市| 黔西县| 区。| 临沭县| 荆门市| 巴楚县| 木里| 伊宁县| 贵德县| 石嘴山市| 景洪市| 漳州市| 香格里拉县| 抚远县|