Android SlidingDrawer ViewFlipper

 SlidingDrawer 和 ViewFlipper 的简单实用:

直接代码:


 xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
    
   <ViewFlipper
       
       android:orientation="vertical" android:id="@+id/ViewFlipper"
        android:layout_width="fill_parent" android:layout_height="55dip"
        android:background="@drawable/gradient_dark_purple"
      >
        
    <LinearLayout
            android:orientation="vertical" android:layout_width="fill_parent"
            android:layout_height="fill_parent" android:gravity="center">
            <Gallery
                android:id="@+id/Gallery"
                android:layout_width="fill_parent"
                android:layout_height="wrap_content" android:spacing="0px"/>
        </LinearLayout>
        
    </ViewFlipper>
    
    
    <SlidingDrawer  android:id="@+id/drawer"
       android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:bottomOffset="7dip"
        android:handle="@+id/handler"
        android:content="@+id/content"
        >
        
        <LinearLayout android:id="@id/handler"
            android:background="@drawable/handle"
            android:layout_width="fill_parent"
            android:orientation="vertical"
            android:layout_height="wrap_content"
             android:gravity="center">
            <ImageView android:layout_width="wrap_content"
            
             android:layout_height="wrap_content" />
        </LinearLayout>
        
       <LinearLayout android:id="@id/content"
            android:background="@drawable/gradient_oriange" android:layout_width="fill_parent"
            android:orientation="vertical" android:layout_height="wrap_content"
            android:gravity="center" android:paddingLeft="20dip"
            android:paddingRight="20dip">
            
            <!-- the content of the sliding-drawer -->
            <LinearLayout android:layout_width="fill_parent"
                android:orientation="horizontal" android:layout_height="wrap_content"
                android:gravity="center">
                <LinearLayout android:layout_width="wrap_content" android:id="@+id/SliderHome"
                    android:layout_marginRight="15dip" android:orientation="vertical"
                    android:layout_height="wrap_content" android:gravity="center"
                    android:onClick="homeClickHandler">
                    <ImageView android:layout_width="wrap_content"
                        android:src="@drawable/icon" android:layout_height="wrap_content" />
                    <TextView android:text="home" android:textColor="#5a5a5a"
                        android:layout_width="wrap_content" android:layout_height="wrap_content"></TextView>
                </LinearLayout>
                <LinearLayout android:layout_width="wrap_content" android:id="@+id/SliderAlbum"
                    android:layout_marginRight="15dip" android:orientation="vertical"
                    android:layout_height="wrap_content" android:gravity="center"
                    android:onClick="albumClickHandler">
                    <ImageView android:layout_width="wrap_content"
                        android:src="@drawable/icon" android:layout_height="wrap_content" />
                    <TextView android:text="album" android:textColor="#5a5a5a"
                        android:layout_width="wrap_content" android:layout_height="wrap_content"></TextView>
                </LinearLayout>
                <LinearLayout android:layout_width="wrap_content" android:id="@+id/SliderArtist"
                    android:layout_marginRight="15dip" android:orientation="vertical"
                    android:layout_height="wrap_content" android:gravity="center"
                    android:onClick="artistClickHandler">
                    <ImageView android:layout_width="wrap_content"
                        android:src="@drawable/icon" android:layout_height="wrap_content" />
                    <TextView android:text="artist" android:textColor="#5a5a5a"
                        android:layout_width="wrap_content" android:layout_height="wrap_content"></TextView>
                </LinearLayout>
                <LinearLayout android:layout_width="wrap_content" android:id="@+id/SliderPlaylist"
                    android:layout_marginRight="15dip" android:orientation="vertical"
                    android:layout_height="wrap_content" android:gravity="center"
                    android:onClick="playlistClickHandler">
                    <ImageView android:layout_width="wrap_content"
                        android:src="@drawable/icon" android:layout_height="wrap_content" />
                    <TextView android:text="playlist"
                        android:textColor="#5a5a5a" android:layout_width="wrap_content"
                        android:layout_height="wrap_content"></TextView>
                </LinearLayout>
            </LinearLayout>
            
            
        </LinearLayout>
        
        
       </SlidingDrawer>
    
</LinearLayout>

Activity 类:


   package com.luke;

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.view.ViewGroup.LayoutParams;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Gallery;
import android.widget.ImageView;
import android.widget.Toast;
import android.widget.ViewFlipper;
import android.widget.AdapterView.OnItemClickListener;

public class mActivity extends Activity {
    
    ViewFlipper  fliper;
    Gallery  galler;
    
    private  int images[] = {R.drawable.no_cd,R.drawable.no_cd,R.drawable.no_cd,R.drawable.no_cd,
            R.drawable.no_cd,R.drawable.no_cd,R.drawable.no_cd};
    
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
       
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.main);
        fliper = (ViewFlipper)findViewById(R.id.ViewFlipper);
        galler = (Gallery)findViewById(R.id.Gallery);
        
        galler.setAdapter(new ImageAdapter(this));
        galler.setOnItemClickListener(new OnItemClickListener(){

            @Override
            public void onItemClick(AdapterView<?> arg0, View arg1, int position,
                    long arg3) {
                
                 Toast.makeText(mActivity.this, "" + position, Toast.LENGTH_SHORT).show();
            }});
    }
    
   class  ImageAdapter  extends BaseAdapter{
       
       private Context context;
       
       ImageAdapter(Context c){
           this.context =c;
       }

    @Override
    public int getCount() {
        
        return  images.length;
    }

    @Override
    public Object getItem(int position) {
        
        return galler.getItemAtPosition(position);
    }

    @Override
    public long getItemId(int arg0) {
        
        return arg0;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
         ImageView  pic;
           
            if (convertView==null){
                pic =  new ImageView (context);
            } else {
                
                pic =  (ImageView) convertView;
            }
            
        
         pic.setImageResource(images[position]);
         pic.setScaleType(ImageView.ScaleType.FIT_CENTER);
         pic.setLayoutParams(new Gallery.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
         
        return  pic;
       }
        
  };
    
    
}


 效果:

    


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值