Gallery使用示例(一)

简介: main.xml如下:   MainActivity如下: import android.os.Bundle;import android.

main.xml如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
   >

    <Gallery 
        android:id="@+id/gallery"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:spacing="10dip"
        android:unselectedAlpha="0.6"
        android:layout_marginTop="30dip"
        android:layout_centerHorizontal="true"
     />
</RelativeLayout>

 

MainActivity如下:

import android.os.Bundle;
import android.app.Activity;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Gallery;
import android.widget.ImageView;
import android.widget.Toast;
import android.widget.AdapterView.OnItemClickListener;
/**
 * Demo描述:
 * 利用Gallery展示图片
 * 问题描述:
 * 在布局文件中为Gallery设置属性
 * android:unselectedAlpha="0.6"
 * 但在运行时出现bug,其余的图片的透明度
 * 亦被设置为0.6.
 * 解决办法:
 * 在BaseAdapter中getView()方法处为每个返回的View设置
 * 透明背景
 *
 */
public class MainActivity extends Activity {
    private int imagesID []= null;
    private Gallery mGallery;
    private BaseAdapter mBaseAdapter;
    @Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		init();
		mGallery.setAdapter(mBaseAdapter);
		mGallery.setOnItemClickListener(new OnItemClickListener() {
			@Override
			public void onItemClick(AdapterView<?> parent, View view,int position, long id) {
				Toast.makeText(getApplicationContext(),
			    "点击了第" + (position + 1) + "张图片", Toast.LENGTH_SHORT).show();
			}
		});
	}
   
	private void init() {
		mGallery=(Gallery) findViewById(R.id.gallery);
		imagesID=new int []{
				R.drawable.a,R.drawable.b,R.drawable.c,R.drawable.d,
				R.drawable.e,R.drawable.f,R.drawable.g,R.drawable.h};
		mBaseAdapter = new BaseAdapter() {
			@Override
			public View getView(int position, View convertView, ViewGroup parent) {
				ImageView imageView = new ImageView(MainActivity.this);
				//设置图片来源
				imageView.setImageResource(imagesID[position]);
				//拉伸图片以填充View的高宽
				imageView.setScaleType(ImageView.ScaleType.FIT_XY);
				//控制显示图片的大小
				imageView.setLayoutParams(new Gallery.LayoutParams(450, 680));
				imageView.setBackgroundColor(0xFF000000);
				return imageView;
			}

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

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

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

}

 

相关文章
|
6月前
|
XML 数据格式
ListView示例(附详解+源码)
ListView示例(附详解+源码)
74 3
|
6月前
|
前端开发
UniApp 中的 image 属性讲解
UniApp 中的 image 属性讲解
830 2
|
6月前
|
小程序 前端开发
【微信小程序】-- 常用的基础内容组件介绍 -- text & rich-text & progress & icon(七)
【微信小程序】-- 常用的基础内容组件介绍 -- text & rich-text & progress & icon(七)
Highcharts柱形范围图使用示例
Highcharts柱形范围图使用示例
43 0
|
Android开发
【Android 安装包优化】Android 中使用 SVG 图片 ( 批量转换 SVG 格式图片为 Vector Asset 矢量图资源 )
【Android 安装包优化】Android 中使用 SVG 图片 ( 批量转换 SVG 格式图片为 Vector Asset 矢量图资源 )
643 0
【Android 安装包优化】Android 中使用 SVG 图片 ( 批量转换 SVG 格式图片为 Vector Asset 矢量图资源 )
|
Android开发 容器