感谢阅读!
我使用Android Gallery同时将LayoutParams作为MATCH_PARENT一次显示一个全屏图像。
这是我的代码:
layout.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent" android:layout_height="fill_parent">
<Gallery
android:id="@+id/gallery" android:layout_width="fill_parent"
android:layout_height="fill_parent">
</Gallery>
<TextView android:id="@+id/tvShowText" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_alignParentBottom="true" />
</RelativeLayout>
HelloGallery.java
package com.android.sagar;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.view.ViewGroup.LayoutParams;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.BaseAdapter;
import android.widget.Gallery;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
public class HelloGallery extends Activity {
TextView tvShowText = null;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
tvShowText = (TextView)findViewById(R.id.tvShowText);
Gallery g = (Gallery) findViewById(R.id.gallery);
g.setAdapter(new ImageAdapter(this));
g.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView parent, View v, int position, long id) {
Toast.makeText(HelloGallery.this, "" + position, Toast.LENGTH_SHORT).show();
}
});
}
public class ImageAdapter extends BaseAdapter {
int mGalleryItemBackground;
private Context mContext;
private Integer[] mImageIds = {
R.drawable.pic1,
R.drawable.pic2,
R.drawable.pic3
};
public ImageAdapter(Context c) {
mContext = c;
}
public int getCount() {
return mImageIds.length;
}
public Object getItem(int position) {
return position;
}
public long getItemId(int position) {
return position;
}
public View getView(int position, View convertView, ViewGroup parent) {
ImageView i = new ImageView(mContext);
tvShowText.setText("ImageCaption for Image No.: "+position);
i.setImageResource(mImageIds[position]);
i.setLayoutParams(new Gallery.LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT));
i.setScaleType(ImageView.ScaleType.FIT_XY);
i.setBackgroundResource(mGalleryItemBackground);
return i;
}
}
}
图像显示正确,但我打印的标题是一个或有时完全不同。 :(
我进行了调试,发现当我滑动一次时,getView()被多次调用 - 大约2到3次......并且它们都是不同的位置但是图像看起来一次只能移动一个。 :( 请帮忙!
答案 0 :(得分:4)
为了正确更新标题,您需要覆盖Gallery
的{{1}}。 Sujit在他的评论中是正确的,OnItemSelectedListener
被调用以便在getView
中呈现(或在某些情况下预渲染或后渲染)每个图像。不应该依赖于识别选择哪个图像。相反,请在Gallery
方法中覆盖OnItemSelectedListener
:
HelloGallery onCreate()
答案 1 :(得分:1)
<强> main.xml中强>
<?xml version="1.0" encoding="utf-8"?>
gallery_image_item.xml
<?xml version="1.0" encoding="utf-8"?>
<ImageView android:id="@+id/gallery_item_liner_image"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:layout_marginTop="7dip" android:layout_centerInParent="true">
</ImageView>
public class SolvedApplication extends Activity {
TextView tvShowText = null;
private Integer[] mImageIds = { R.drawable.icon, R.drawable.icon,
R.drawable.icon };
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
tvShowText = (TextView) findViewById(R.id.tvShowText);
Gallery g = (Gallery) findViewById(R.id.gallery);
g.setAdapter(new ImageAdapter(this));
g.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView parent, View v, int position,
long id) {
Toast.makeText(SolvedApplication.this, "" + position,
Toast.LENGTH_SHORT).show();
}
});
}
public class ImageAdapter extends BaseAdapter {
int mGalleryItemBackground;
private Context mContext;
public ImageAdapter(Context c) {
mContext = c;
}
public int getCount() {
return mImageIds.length;
}
public Object getItem(int position) {
return position;
}
public long getItemId(int position) {
return position;
}
public View getView(int position, View convertView, ViewGroup parent) {
final ViewHolder holder;
tvShowText.setText("ImageCaption for Image No.: " + position);
View rowView = convertView;
if (rowView == null) {
holder = new ViewHolder();
LayoutInflater inflater = (LayoutInflater) getApplicationContext()
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
rowView = inflater.inflate(R.layout.gallery_image_item, null);
holder.mainImage = (ImageView) rowView
.findViewById(R.id.gallery_item_liner_image);
rowView.setTag(holder);
} else {
holder = (ViewHolder) rowView.getTag();
}
holder.mainImage.setImageResource(mImageIds[position]);
return rowView;
}
}
// Class used for gallery view
static class ViewHolder {
private ImageView mainImage, selectionImage;
}
}
答案 2 :(得分:0)
以下是Change border style in Gallery所需的代码,可在图像周围获得20像素的黑色边框。这似乎是发布它的最佳地点。请在这里或那里投票给我。
public View getView(int position, View convertView, ViewGroup parent) {
ImageView i = new ImageView(mContext);
i.setImageResource(mImageIds[position]);
i.setLayoutParams(new Gallery.LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT));
i.setScaleType(ImageView.ScaleType.FIT_XY);
i.setBackgroundResource(mGalleryItemBackground);
RelativeLayout borderImg = new RelativeLayout(mContext);
borderImg.setPadding(20,20,20,20);
borderImg.setBackgroundColor(0xff000000);
borderImg.addView(i);
return borderImg;
}