通过单击ImageButton弹出Dialog,在Dialog中使用,显示Gallery,通过选择Gallery中的图片设置ImageButton中的图像。
主页面截图:
主布局文件main_activity.xml布局文件
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >
<ImageButton
android:id="@+id/imageButton1"
android:onClick="popDialog"
android:layout_width="70dp"
android:layout_height="70dp"
android:layout_alignParentLeft="true"
android:layout_marginTop="19dp"
android:src="@drawable/ic_launcher" />
<EditText
android:id="@+id/editText1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/imageButton1"
android:layout_marginLeft="40dp"
android:layout_toRightOf="@+id/imageButton1"
android:ems="10" >
<requestFocus />
</EditText>
</RelativeLayout>
main_gallery的主代码:
<!-- <?xml version="1.0" encoding="utf-8"?>
<Gallery
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/Gallery01"
android:layout_width="70dp"
android:layout_height="60dp"
/> -->
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >
<Gallery
android:id="@+id/gallery"
android:spacing="10dp"
android:layout_width="fill_parent"
android:layout_height="wrap_content" />
</RelativeLayout>
点击ImageButton之后的的效果:
主代码MainActivity.java:
package com.example.l3_dialog;
import android.app.Activity;
import android.app.AlertDialog;
import android.app.Dialog;
import android.content.Context;
import android.content.DialogInterface;
import android.content.DialogInterface.OnClickListener;
import android.os.Bundle;
import android.support.v4.view.ViewPager.LayoutParams;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.View;
import android.view.View.OnCreateContextMenuListener;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.AdapterView.OnItemSelectedListener;
import android.widget.BaseAdapter;
import android.widget.Gallery;
import android.widget.ImageButton;
import android.widget.ImageView;
public class MainActivity extends Activity {
private ImageButton imagebutton;
private Gallery gallery;
private Integer[] photo = { R.drawable.sample_thumb_0,
R.drawable.sample_thumb_1, R.drawable.sample_thumb_2,
R.drawable.sample_thumb_3, R.drawable.sample_thumb_4,
R.drawable.sample_thumb_5 };
int pos = photo.length / 2;
int IMAGES = 1;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
imagebutton = (ImageButton) this.findViewById(R.id.imageButton1);
imagebutton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
showDialog(IMAGES);
}
});
}
@Override
protected Dialog onCreateDialog(int id) {
AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);
LayoutInflater inflater = LayoutInflater.from(MainActivity.this);
final View view = inflater.inflate(R.layout.activity_gallery, null);
builder.setTitle("请选择你的头像:");
builder.setView(view);
gallery = (Gallery) view.findViewById(R.id.gallery);
gallery.setSelection(photo.length / 2);
gallery.setAdapter(new ImageAdapter());
gallery.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,
long arg3) {
pos = arg2;
}
});
builder.setNegativeButton("取消", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
removeDialog(IMAGES);
;}
});
builder.setPositiveButton("确定", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
removeDialog(IMAGES);
imagebutton.setImageResource(photo[pos]);
}
});
return builder.create();
}
private class ImageAdapter extends BaseAdapter {
@Override
public int getCount() {
return photo.length;
}
@Override
public Object getItem(int position) {
return position;
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ImageView img = new ImageView(MainActivity.this);
// 设置图片资源
img.setImageResource(photo[position]);
// 保持宽高比,不设置则gallery显示一张图片
img.setAdjustViewBounds(true);
// 设置固定大小
img.setMaxHeight(100);
img.setMaxWidth(140);
img.setScaleType(ImageView.ScaleType.FIT_CENTER);
// 设置图片大小
img.setLayoutParams(new Gallery.LayoutParams(
LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
return img;
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}
执行后的效果: