【Android UI設計與開發】9:滑動菜單欄(一)開源項目SlidingMenu的使用和示例-轉

1、SlidingMenu簡介html

     相信你們對SlidingMenu都不陌生了,它是一種比較新的設置界面或配置界面的效果,在主界面左滑或者右滑出現設置界面效果,能方便的進行各類操做。不少優秀的應用都採用了這種界面方案,像facebook、人人網、everynote、Google+等等。以下圖所示:android

 由於效果確實比較新穎,因此在不少的應用開發中去實現此效果,解決的辦法也是不盡相同。諸多比較之後發git

現,仍是GitHub上的開源項目SlidingMenu提供了最佳的實現:定製靈活、各類陰影和漸變以及動畫的滑動效果都很不錯。不過這是一個開源庫,而不是一個完整的項目,要把它做爲libary引入到你本身的工程裏,簡單配置一下就能夠實現SlidingMenu的效果。github

2、SlidingMenu使用app

 slidingmenu_library下載地址:https://github.com/YeXiaoChao/slidingmenu_libraryide

要想可以實現SlidingMenu的效果,首先必需要將它做爲libary導入到你的工程佈局

一、下載完畢以後,將此項目導入Eclipse開發環境中post

 

二、導入項目以後,而後在新建一個Android項目,將slidingmenu_library導入新建的Android項目中,步驟以下:動畫

<1> 右鍵點擊新建的Android項目,而後點擊最下方的「Properties」選項;ui

<2> 點擊彈出對話框以後,在最左側選擇「Android」選項,而後再點擊右下方的「Add」按鈕;

<3> 點擊後彈出對話框,選中以前導入的slidingmenu_library項目

<4> 選中以後如圖所示;

<5> 這就說明了導入庫已經成功了,導入成功以後會在Android的引用包中出現一個slidingmenu_library.jar包;

 

注意:這裏有個地方須要你們特別注意一下,在新建完Android項目以後,較新的Eclipse版本都會在Android目錄下生成一個libs的文件夾,裏面會有一個android-support-v4.jar的jar包,這個jar必定要記得刪掉,不然運行程序的時候會出現異常,提示是找不到類的異常。出現異常的緣由是由於在導入slidingmenu_library類庫的時候,這個類庫裏面自己就包含了android-support-v4.jar的jar包,因此運行的時候就會出現異常,系統不知道去調用哪一個路徑的下的包,因此程序崩潰,提示找不到類。

 

、SlidingMenu示例

1.效果圖片(GIF圖片比較大,有3.6M)

 

2.代碼講解

一、項目結構圖

 

 

二、content_frame.xml佈局

複製代碼
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/menu_frame"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />
<!-- 定義一個虛擬的視圖,方便Fragment可以替換該視圖,以達到Fragment的視圖內容可以顯示在屏幕上的效果。 -->
複製代碼

 

三、menu_frame.xml佈局

複製代碼
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/menu_frame"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />

<!-- 用來存放滑動菜單打開後的視圖界面的。 -->
複製代碼

 

四、list.xml

複製代碼
<?xml version="1.0" encoding="utf-8"?>
<ListView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@android:id/list"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingLeft="@dimen/list_padding"
    android:paddingRight="@dimen/list_padding" />
<!-- 這個list佈局文件會在ListFragment中用到。 -->
複製代碼

 

五、row.xml

複製代碼
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="50dp"
    android:orientation="horizontal" >

    <ImageView
        android:id="@+id/row_icon"
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:padding="10dp"
        android:src="@drawable/ic_launcher" />

    <TextView
        android:id="@+id/row_title"
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:gravity="center_vertical"
        android:padding="10dp"
        android:text="Medium Text"
        android:textAppearance="@android:style/TextAppearance.Medium" />

</LinearLayout>
<!-- 用於存放列表中的圖片和文本。 -->
複製代碼

 

六、shadow.xml資源

複製代碼
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >

    <gradient
        android:centerColor="#11000000"
        android:endColor="#33000000"
        android:startColor="#00000000" />

</shape>
<!-- 用來實現陰影效果的圖形,使用了漸變的繪圖效果。 -->
複製代碼

 

七、SampleListFragment類

複製代碼
package com.yanis.slidingmenu;

import android.content.Context;
import android.os.Bundle;
import android.support.v4.app.ListFragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.TextView;

/**
 * 劃出的菜單欄 - 用來顯示界面中的列表的。
 */
public class SampleListFragment extends ListFragment {

    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        return inflater.inflate(R.layout.list, null);
    }

    public void onActivityCreated(Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);
        
        SampleAdapter adapter = new SampleAdapter(getActivity());
        
        for (int i = 0; i < 20; i++) {
            adapter.add(new SampleItem("Sample List", android.R.drawable.ic_menu_search));
        }
        setListAdapter(adapter);
    }
    
    public class SampleAdapter extends ArrayAdapter<SampleItem> {
        public SampleAdapter(Context context) {
            super(context, 0);
        }

        public View getView(int position, View convertView, ViewGroup parent) {
            if (convertView == null) {
                convertView = LayoutInflater.from(getContext()).inflate(R.layout.row, null);
            }
            ImageView icon = (ImageView) convertView.findViewById(R.id.row_icon);
            icon.setImageResource(getItem(position).iconRes);
            TextView title = (TextView) convertView.findViewById(R.id.row_title);
            title.setText(getItem(position).tag);

            return convertView;
        }
    }
    
    private class SampleItem {
        public String tag;
        public int iconRes;
        public SampleItem(String tag, int iconRes) {
            this.tag = tag; 
            this.iconRes = iconRes;
        }
    }
}
複製代碼

 

八、SlidingMenuActivity_一、SlidingMenuActivity_2等類

這些類是對SlidingMenu的屬性進行設置,下面放個簡單的,具體能夠查看源代碼

複製代碼
package com.yanis.slidingmenu;

import android.os.Bundle;
import android.support.v4.app.FragmentActivity;

import com.jeremyfeinstein.slidingmenu.lib.SlidingMenu;

/**
 * 
 * @author yechao
 * @說明 一個簡單的放置在左邊滑動菜單欄的效果
 */
public class SlidingMenuActivity_2 extends FragmentActivity {
    private SlidingMenu menu;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        // 設置標題
        setTitle("Attach");

        // 初始化滑動菜單
        initSlidingMenu();
    }

    /**
     * 初始化滑動菜單
     */
    private void initSlidingMenu() {
        // 設置主界面視圖
        setContentView(R.layout.content_frame);
        getSupportFragmentManager().beginTransaction()
                .replace(R.id.content_frame, new SampleListFragment()).commit();

        // 設置滑動菜單的屬性值
        menu = new SlidingMenu(this);
        menu.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);
        menu.setShadowWidthRes(R.dimen.shadow_width);
        menu.setShadowDrawable(R.drawable.shadow);
        menu.setBehindOffsetRes(R.dimen.slidingmenu_offset);
        menu.setFadeDegree(0.35f);
        menu.attachToActivity(this, SlidingMenu.SLIDING_CONTENT);
        // 設置滑動菜單的視圖界面
        menu.setMenu(R.layout.menu_frame);
        getSupportFragmentManager().beginTransaction()
                .replace(R.id.menu_frame, new SampleListFragment()).commit();
    }

    @Override
    public void onBackPressed() {
        // 點擊返回鍵關閉滑動菜單
        if (menu.isMenuShowing()) {
            menu.showContent();
        } else {
            super.onBackPressed();
        }
    }

}
複製代碼

 

源代碼地址:https://github.com/YeXiaoChao/Yc_ui_slidingmenu

本文地址:http://www.cnblogs.com/yc-755909659/p/4306938.html

來源文章:

http://blog.csdn.net/yangyu20121224/article/details/9255829

http://blog.csdn.net/yangyu20121224/article/details/9258275

 
相關文章
相關標籤/搜索