真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Android開源框架的SlidingFragment的使用示例

效果如下:

為開原等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及開原網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為做網(wǎng)站、網(wǎng)站設(shè)計(jì)、開原網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

Android開源框架的SlidingFragment的使用示例

直接上代碼,留著以后用,代碼目錄結(jié)構(gòu)如下:

Android開源框架的SlidingFragment的使用示例

其中BaseFragment.java是另外5個(gè)Fragment的基類,代碼如下:

package com.xuliugen.newsclient.fragment.base;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
/**
 * Fragment的基類
 * 
 * @author xuliugen
 * 
 */
public class BaseFragment extends Fragment {
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
  }
  @Override
  public View onCreateView(LayoutInflater inflater, ViewGroup container,
      Bundle savedInstanceState) {
    TextView textView = new TextView(getActivity());
    textView.setText(this.getClass().getSimpleName()); // 獲取當(dāng)前對(duì)象對(duì)應(yīng)的類名稱
    return textView;
  }
  public void onActivityCreated(Bundle savedInstanceState) {
    super.onActivityCreated(savedInstanceState);
  };
}

另外5個(gè)Fragment的代碼都一樣就是直接繼承BaseFragment.java沒有任何實(shí)現(xiàn),其他4個(gè)省略

public class Fragment1 extends BaseFragment {
}

MenuFragment.java是用于管理這幾個(gè)Fragment的

package com.xuliugen.newsclient.fragment;
import java.util.ArrayList;
import java.util.List;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import com.xuliugen.newsclient.MainActivity;
import com.xuliugen.newsclient.R;
import com.xuliugen.newsclient.fragment.base.BaseFragment;
/**
 * 繼承Fragment要自己實(shí)現(xiàn)的方法
 * 
 * 用于填充側(cè)滑菜單中的數(shù)據(jù)
 * 
 * OnItemClickListener:listview里邊的點(diǎn)擊事件
 * 
 * @author xuliugen
 * 
 */
public class MenuFragment extends Fragment implements OnItemClickListener {
  View view;
  private String tag = "MenuFragment";
  /**
   * 當(dāng)activity創(chuàng)建的時(shí)候加載數(shù)據(jù)
   */
  @Override
  public void onActivityCreated(Bundle savedInstanceState) {
    super.onActivityCreated(savedInstanceState);
    Log.i(tag, "onActivityCreated");
    ListView listView = (ListView) view.findViewById(R.id.list_view);
    ArrayAdapter adapter = new ArrayAdapter(getActivity(),
        android.R.layout.simple_list_item_1, android.R.id.text1,
        iniData());
    listView.setAdapter(adapter);// 設(shè)置適配器
    listView.setOnItemClickListener(this);
  }
  /**
   * 側(cè)邊欄的靜態(tài)數(shù)據(jù)
   * 
   * @return
   */
  private List iniData() {
    List list = new ArrayList();
    list.add("fragment1");
    list.add("fragment2");
    list.add("fragment3");
    list.add("fragment4");
    list.add("fragment5");
    return list;
  }
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    Log.i(tag, "onCreate");
  }
  /**
   * 用于加載側(cè)邊欄
   */
  @Override
  public View onCreateView(LayoutInflater inflater, ViewGroup container,
      Bundle savedInstanceState) {
    Log.i(tag, "onCreateView");
    // 加載界面:側(cè)邊欄
    view = LayoutInflater.from(getActivity()).inflate(R.layout.list_view,
        null);
    return view;
  }
  /**
   * listview中點(diǎn)擊事件的監(jiān)聽器 選擇監(jiān)聽事件
   */
  @Override
  public void onItemClick(AdapterView<?> parent, View view, int position,
      long id) {
    BaseFragment baseFragment = null;
    switch (position) {
    case 0:
      baseFragment = new Fragment1();
      break;
    case 1:
      baseFragment = new Fragment2();
      break;
    case 2:
      baseFragment = new Fragment3();
      break;
    case 3:
      baseFragment = new Fragment4();
      break;
    case 4:
      baseFragment = new Fragment5();
      break;
    }
    /**
     * 讓baseFragment替換界面
     */
    /*
     * getActivity().getSupportFragmentManager() // 獲取fragment的管理者
     * .beginTransaction() // 開啟事物 .replace(R.id.content_frag, baseFragment,
     * "Home")// 替換,將menuFragment中的數(shù)據(jù)替換到R.id.menu_frag中 .commit();// 提交
     */
    // 通過switch選擇,相當(dāng)于一個(gè)回調(diào)方法
    switchFragment(baseFragment);
  }
  private void switchFragment(BaseFragment fragment) {
    if (fragment != null) {
      if (getActivity() instanceof MainActivity) {
        ((MainActivity) getActivity()).switchFragment(fragment);
      }
    }
  }
}

MainActivity.java主要是用于初始化SlidingFragmentActivity的操作,設(shè)置參數(shù)等

package com.xuliugen.newsclient;
import android.os.Bundle;
import android.view.Window;
import com.jeremyfeinstein.slidingmenu.lib.SlidingMenu;
import com.jeremyfeinstein.slidingmenu.lib.app.SlidingFragmentActivity;
import com.xuliugen.newsclient.fragment.Fragment1;
import com.xuliugen.newsclient.fragment.MenuFragment;
import com.xuliugen.newsclient.fragment.base.BaseFragment;
/**
 * 使用滑動(dòng)菜單首先要繼承SlidingFragmentActivity,然后實(shí)現(xiàn)的一般步驟如下:
 * 
 * 1.得到滑動(dòng)菜單
 * 
 * 2.設(shè)置滑動(dòng)菜單是在左邊還是在右邊出來
 * 
 * 3.設(shè)置滑動(dòng)菜單出來之后,內(nèi)容頁,顯示的剩余寬度
 * 
 * 4.設(shè)置滑動(dòng)菜單的陰影設(shè)置陰影,陰影需要在開始的時(shí)候特別淡,慢慢變暗
 * 
 * 5.設(shè)置陰影的寬度
 * 
 * 6.設(shè)置滑動(dòng)菜單的范圍
 * 
 * @author xuliugen
 * 
 */
public class MainActivity extends SlidingFragmentActivity {
  SlidingMenu slidingMenu;
  @Override
  public void onCreate(Bundle savedInstanceState) {
    requestWindowFeature(Window.FEATURE_NO_TITLE);
    super.onCreate(savedInstanceState);
    setBehindContentView(R.layout.menu); // 加載SlidingFragment的初始化
    setContentView(R.layout.content);// 這里是動(dòng)態(tài)加載的頁面
    // 設(shè)置content內(nèi)容中的初始值
    Fragment1 fragment1 = new Fragment1();
    getSupportFragmentManager()//
        .beginTransaction()//
        .replace(R.id.content_frag, fragment1)//
        .commit();//
    // 1.得到滑動(dòng)菜單
    slidingMenu = getSlidingMenu();
    // 2.設(shè)置滑動(dòng)菜單是在左邊還是在右邊出來(左、右、左右)
    slidingMenu.setMode(SlidingMenu.LEFT);
    // 3.設(shè)置滑動(dòng)菜單出來之后,內(nèi)容頁,顯示的剩余寬度
    slidingMenu.setBehindWidthRes(R.dimen.slidingmenu_offset);
    // 4.設(shè)置滑動(dòng)菜單的陰影設(shè)置陰影,陰影需要在開始的時(shí)候特別淡,慢慢變暗
    slidingMenu.setShadowDrawable(R.drawable.shadow);
    // 5.設(shè)置陰影的寬度
    slidingMenu.setShadowWidth(R.dimen.shadow_width);
    // 6.設(shè)置滑動(dòng)菜單的范圍
    // SlidingMenu.TOUCHMODE_FULLSCREEN:全屏
    // SlidingMenu.TOUCHMODE_MARGIN:邊沿的時(shí)候滑動(dòng)
    // SlidingMenu.TOUCHMODE_NONE:不滑動(dòng)
    slidingMenu.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);
    // 創(chuàng)建fragmentment
    MenuFragment menuFragment = new MenuFragment();
    getSupportFragmentManager() // 獲取fragment的管理者
        .beginTransaction() // 開啟事物
        .replace(R.id.menu_frag, menuFragment, "Menu")// 替換,將menuFragment中的數(shù)據(jù)替換到R.id.menu_frag中
        .commit();// 提交
  }
  /**
   * 方法回調(diào):在MenuFragment類中進(jìn)行調(diào)用
   * 暴露替換幀布局內(nèi)容的操作
   * @param fragment
   */
  public void switchFragment(BaseFragment fragment) {
    getSupportFragmentManager()//
        .beginTransaction()//
        .replace(R.id.content_frag, fragment)//
        .commit();
    slidingMenu.toggle();// 點(diǎn)擊之后自動(dòng)切換
  }
}

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)創(chuàng)新互聯(lián)的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接


網(wǎng)站標(biāo)題:Android開源框架的SlidingFragment的使用示例
本文地址:http://weahome.cn/article/gddhpe.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部