android:gallery 와 imageSwitch 를 사용 하여 좌우 로 순환 하여 미 끄 러 질 수 있 는 그림 브 라 우 저 를 만 듭 니 다.

그림 브 라 우 저 좌우 가 무한 순환 으로 미 끄 러 지기 위해 서 는 갤러리 의 adapter 를 사용자 정의 해 야 합 니 다.
adapter 를 사용자 정의 하려 면 먼저 이 몇 가지 방법 을 알 아야 합 니 다.
@Override
	public int getCount() {
		// TODO Auto-generated method stub
		return 0;
	}

	@Override
	public Object getItem(int position) {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public long getItemId(int position) {
		// TODO Auto-generated method stub
		return 0;
	}

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		// TODO Auto-generated method stub
		return null;
	}

그 중에서 getCount 방법 은 데이터 원본 의 수량 을 되 돌려 주 는 것 입 니 다.
getItem 방법 은 object 대상 을 되 돌려 줍 니 다.즉,현재 용기 의 데이터 ID position 에 대응 하 는 대상 을 되 돌려 줍 니 다.
getItemId 는 현재 용기 의 데이터 ID 를 되 돌려 줍 니 다.
getView 현재 표시 할 View 가 져 오기
좌우 순환 미끄럼 을 실현 하려 면 먼저 데이터 원본 의 수량 을 최대 값 으로 되 돌려 주 고 모든 데이터 의 ID 를 원래 데이터 원본 의 수량 에 남 겨 야 합 니 다.  마지막 으로 갤러리 의 초기 위 치 를 0-최대 값 의 중간 에 설정 하면 됩 니 다.
변 경 된 adapter 는 이 렇 습 니 다.
package com.example.imageswitcher;

import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Gallery;
import android.widget.ImageView;
import android.widget.ImageView.ScaleType;

public class MyAdapter extends BaseAdapter{

	private int id_image[];
	private Context contex;
	public MyAdapter(Context contex,int id_image[]) {
		this.contex=contex;
		this.id_image=id_image;
	}

	@Override
	public int getCount() {
		// TODO Auto-generated method stub
		return Integer.MAX_VALUE;
	}

	@Override
	public Object getItem(int position) {
		// TODO Auto-generated method stub
		return id_image[position%id_image.length];
	}

	@Override
	public long getItemId(int position) {
		// TODO Auto-generated method stub
		return position%id_image.length;
	}

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		// TODO Auto-generated method stub
		ImageView imageView=new ImageView(contex);
		imageView.setBackgroundResource(id_image[position%id_image.length]);
		imageView.setLayoutParams(new Gallery.LayoutParams(250, 200));
		imageView.setScaleType(ScaleType.FIT_XY);
		return imageView;
	}

}

MainActivity
package com.example.imageswitcher;

import android.os.Bundle;
import android.app.Activity;
import android.view.LayoutInflater.Factory;
import android.view.Menu;
import android.view.View;
import android.view.Window;
import android.view.animation.AnimationUtils;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemSelectedListener;
import android.widget.Gallery;
import android.widget.ImageSwitcher;
import android.widget.ImageView;
import android.widget.ImageView.ScaleType;
import android.widget.ViewSwitcher.ViewFactory;

public class MainActivity extends Activity implements OnItemSelectedListener,ViewFactory{

	private ImageSwitcher imageSwitcher;
	private Gallery gallery;
	private int id_image[] = { R.drawable.beauty1, R.drawable.beauty2,
			R.drawable.beauty3, R.drawable.beauty4, R.drawable.beauty5,
			R.drawable.beauty6, R.drawable.beauty7, R.drawable.beauty8,
			R.drawable.beauty9};
	private MyAdapter myAdapter;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		requestWindowFeature(Window.FEATURE_NO_TITLE);
		setContentView(R.layout.activity_main);
		gallery = (Gallery) findViewById(R.id.id_gallery);
		imageSwitcher = (ImageSwitcher) findViewById(R.id.id_imageSwitcher);
		myAdapter=new MyAdapter(this, id_image);
		imageSwitcher.setFactory(this);
		gallery.setOnItemSelectedListener(this);
		//        
		imageSwitcher.setInAnimation(AnimationUtils.loadAnimation(this, android.R.anim.fade_in));
		imageSwitcher.setOutAnimation(AnimationUtils.loadAnimation(this, android.R.anim.fade_out));
		gallery.setAdapter(myAdapter);	
		//         gallery          
		gallery.setSelection(id_image.length*100);
	}

	@Override
	public void onItemSelected(AdapterView<?> parent, View view, int position,
			long id) {
		// TODO Auto-generated method stub
		imageSwitcher.setBackgroundResource(id_image[position%id_image.length]);
	}

	@Override
	public void onNothingSelected(AdapterView<?> parent) {
		// TODO Auto-generated method stub
		
	}

	@Override
	public View makeView() {
		// TODO Auto-generated method stub
		ImageView image=new ImageView(this);
		image.setScaleType(ScaleType.FIT_CENTER);
		return image;
	}
}

좋은 웹페이지 즐겨찾기