欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android編程實(shí)現(xiàn)抽屜效果的方法詳解

 更新時(shí)間:2017年05月30日 09:34:16   作者:android小豬  
這篇文章主要介紹了Android編程實(shí)現(xiàn)抽屜效果的方法,結(jié)合具體實(shí)例形式分析了Android實(shí)現(xiàn)抽屜效果的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了Android編程實(shí)現(xiàn)抽屜效果的方法。分享給大家供大家參考,具體如下:

android的UI開發(fā)確實(shí)是一件很有趣的事情,也是一件很有挑戰(zhàn)性的事情。

本文章是將自己在開發(fā)中的項(xiàng)目中使用到的比較好的抽屜效果的原理以及代碼整理后寫上來的,以備忘記后可以查閱

抽屜效果的原理很簡(jiǎn)單,就是給其一個(gè)事件監(jiān)聽(動(dòng)作),然后對(duì)此動(dòng)作所作出的反應(yīng)(開 or 關(guān));

在編寫代碼的時(shí)候要注意的幾點(diǎn)如下:

1、 打開抽屜的圖標(biāo)(即觸發(fā)抽屜的把手),打開后的界面都是布局在<SlidingDrawer/><SlidingDrawer/>標(biāo)簽中
2、在<SlidingDrawer/>與<SlidingDrawer/>標(biāo)簽中設(shè)置:android:handle="@+id/handle_layout" 用來指定抽屜的把手;設(shè)置:android:content="@+id/content_layout" 用來指定打開       抽屜后的View(即抽屜里面的內(nèi)容)
3、 SlidingDrawer一共有三個(gè)監(jiān)聽事件(見代碼)

注意:三者的執(zhí)行順序,總的原則是:滑動(dòng)完成后,打開(或者關(guān)閉)抽屜

執(zhí)行的順序:

1 、setOnDrawerScrollListener(給把手一個(gè)動(dòng)作)
2、 setOnDrawerOpenListener(打開抽屜) 或 setOnDrawerCloseListener(關(guān)閉抽屜)

下面是代碼:

activity_main.xml:

<!-- 在SlidingDrawer這個(gè)標(biāo)簽下android:handle:指示的就是抽屜的圖片。
android:content:指向的就是抽屜里面的布局。有了這個(gè)布局,其實(shí)一個(gè)抽屜就出來了 -->
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent" >
  <TextView
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="@string/hello"
    android:textSize="20sp" />
  <SlidingDrawer
    android:id="@+id/sd"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:content="@+id/myContent"
    android:handle="@+id/iv"
    android:orientation="vertical" >
    <ImageView
      android:id="@id/iv"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:src="@drawable/open1" />
    <GridView
      android:id="@id/myContent"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:background="@drawable/background"
      android:gravity="center"
      android:numColumns="3" />
  </SlidingDrawer>
</RelativeLayout>

MainActivity.java 中主要的代碼如下:

package com.example.exp_sliding;
import android.os.Bundle;
import android.app.Activity;
import android.widget.GridView;
import android.widget.ImageView;
import android.widget.SlidingDrawer;
import android.widget.SlidingDrawer.OnDrawerScrollListener;
@SuppressWarnings("deprecation")
public class MainActivity extends Activity {
  private GridView gridView;
  private SlidingDrawer slidingDrawer;
  private ImageView imageView;
  private int[] icons = { R.drawable.one, R.drawable.two, R.drawable.three,
      R.drawable.four, R.drawable.five, R.drawable.six, R.drawable.seven,
      R.drawable.eight, R.drawable.nine };
  private String[] items = { "one", "two", "three", "four", "five", "six",
      "seven", "eight", "nine" };
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    gridView = (GridView) findViewById(R.id.myContent);
    slidingDrawer = (SlidingDrawer) findViewById(R.id.sd);
    imageView = (ImageView) findViewById(R.id.iv);
    // 自定義MyAdapter來實(shí)現(xiàn)圖標(biāo)加item的顯示效果
    MyAdapter adapter = new MyAdapter(this, items, icons);
    gridView.setAdapter(adapter);
    //滑動(dòng)
    slidingDrawer.setOnDrawerScrollListener(new OnDrawerScrollListener() {
        public void onScrollStarted() {
          System.out.println("--------> 開始滑動(dòng)");
        }
        public void onScrollEnded() {
         System.out.println("--------> 滑動(dòng)結(jié)束");
        }
    });
    //開抽屜動(dòng)作響應(yīng)
    slidingDrawer.setOnDrawerOpenListener(new SlidingDrawer.OnDrawerOpenListener()
        {
          @Override
          public void onDrawerOpened() {
            imageView.setImageResource(R.drawable.close1);// 響應(yīng)開抽屜事件
          }
        });
    //關(guān)抽屜動(dòng)作響應(yīng)
    slidingDrawer.setOnDrawerCloseListener(new SlidingDrawer.OnDrawerCloseListener() {
          @Override
          public void onDrawerClosed() {
            imageView.setImageResource(R.drawable.open1);// 響應(yīng)關(guān)抽屜事件
          }
        });
  }
}

這是一個(gè)很基礎(chǔ)的上下開關(guān)抽屜的例子,其中涉及的MyAdapter類是一個(gè)圖片的收集器,這個(gè)相信大家有一定基礎(chǔ)的都會(huì)寫這個(gè)吧,由于時(shí)間關(guān)系,在這里就不貼出來了。

更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android布局layout技巧總結(jié)》、《Android視圖View技巧總結(jié)》、《Android線程與消息機(jī)制用法總結(jié)》、《Android編程之a(chǎn)ctivity操作技巧總結(jié)》、《Android調(diào)試技巧與常見問題解決方法匯總》、《Android開發(fā)入門與進(jìn)階教程》、《Android基本組件用法總結(jié)》及《Android控件用法總結(jié)

希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Win10下Android App安裝配置開發(fā)環(huán)境

    Win10下Android App安裝配置開發(fā)環(huán)境

    這篇文章主要為大家詳細(xì)介紹了Win10下Android App安裝配置開發(fā)環(huán)境,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • Android 實(shí)現(xiàn)仿QQ拖拽氣泡效果的示例

    Android 實(shí)現(xiàn)仿QQ拖拽氣泡效果的示例

    這篇文章主要介紹了Android 實(shí)現(xiàn)仿QQ拖拽氣泡效果的示例,幫助大家更好的理解和學(xué)習(xí)使用Android,感興趣的朋友可以了解下
    2021-04-04
  • Android自定義加載圈動(dòng)畫效果

    Android自定義加載圈動(dòng)畫效果

    這篇文章主要為大家詳細(xì)介紹了Android自定義加載圈動(dòng)畫效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Android android:exported = true 用法詳解

    Android android:exported = true 用法詳解

    在本篇文章里小編給大家整理了關(guān)于Android android:exported = true 用法,需要的朋友們參考下。
    2019-09-09
  • Android實(shí)現(xiàn)折線走勢(shì)圖

    Android實(shí)現(xiàn)折線走勢(shì)圖

    這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)折線走勢(shì)圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • Android Fragment 基本了解(圖文介紹)

    Android Fragment 基本了解(圖文介紹)

    Android是在Android 3.0 (API level 11)開始引入Fragment的可以把Fragment想成Activity中的模塊,這個(gè)模塊有自己的布局,有自己的生命周期,單獨(dú)處理自己的輸入,在Activity運(yùn)行的時(shí)候可以加載或者移除Fragment模塊
    2013-01-01
  • Android應(yīng)用中使用ContentProvider掃描本地圖片并顯示

    Android應(yīng)用中使用ContentProvider掃描本地圖片并顯示

    這篇文章主要介紹了Android應(yīng)用中使用ContentProvider掃描本地圖片并顯示的方法,比調(diào)用本地圖庫(kù)的方法更加靈活和可定制,需要的朋友可以參考下
    2016-04-04
  • Jetpack?Compose狀態(tài)專篇精講

    Jetpack?Compose狀態(tài)專篇精講

    在今年的Google/IO大會(huì)上,亮相了一個(gè)全新的?Android?原生?UI?開發(fā)框架-Jetpack?Compose,?與蘋果的SwiftIUI一樣,Jetpack?Compose是一個(gè)聲明式的UI框架,這篇文章主要介紹了Jetpack?Compose狀態(tài)管理
    2022-10-10
  • Flutter實(shí)現(xiàn)編寫富文本Text的示例代碼

    Flutter實(shí)現(xiàn)編寫富文本Text的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何通過Flutter實(shí)現(xiàn)編寫富文本Text,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,需要的可以參考一下
    2022-11-11
  • 從0快速搭建一個(gè)實(shí)用的MVVM框架(超詳細(xì))

    從0快速搭建一個(gè)實(shí)用的MVVM框架(超詳細(xì))

    這篇文章主要介紹了從0搭建一個(gè)實(shí)用的MVVM框架,結(jié)合Jetpack,構(gòu)建快速開發(fā)的MVVM框架,支持快速生成ListActivity、ListFragment,主要是基于MVVM進(jìn)行快速開發(fā)上手即用,需要的朋友可以參考下
    2022-03-03

最新評(píng)論