3

谢谢阅读!

我使用 Android Gallery 和 LayoutParams 作为 MATCH_PARENT 一次显示一个全屏图像。

这是我的代码:

布局.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 次......它们都是不同的位置,但图像似乎一次移动一个。:( 请帮忙!

4

3 回答 3

4

为了正确更新您的标题,您需要覆盖Gallery's OnItemSelectedListener。Sujit 在他的评论中是正确的,该评论getView被调用以渲染(或在某些情况下预渲染或后渲染)Gallery. 不应依赖于识别选择了哪个图像。相反,OnItemSelectedListener在您的HelloGallery onCreate()方法中覆盖:

    g.setOnItemSelectedListener(new OnItemSelectedListener() 
    {
       @Override
       public void onItemSelected(AdapterView<?> parent, View view, int position, long id) 
       {
          tvShowText.setText("ImageCaption for Image No.: "+position);
       }
       @Override
       public void onNothingSelected(AdapterView<?> arg0) 
       {
          tvShowText.setText("No image selected");
       }
    });            
于 2011-05-19T19:01:47.403 回答
1

主要的.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;
}

}

于 2011-05-19T12:47:24.250 回答
0

这是您从更改图库中的边框样式中需要的代码,以在图像周围获得 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;
    }
于 2011-05-19T19:35:41.210 回答