Получить галерею, чтобы начать на определенной позиции - PullRequest
4 голосов
/ 02 января 2012

Я создаю раздел галереи для своего приложения, который будет использоваться для отображения количества изображений X.Эти изображения загружаются с внешнего сервера.Пользователю показывается GridView, содержащий миниатюры изображений, и после нажатия на эти миниатюры открывается окно Gallery, которое показывает изображение в полноэкранном режиме.ArrayList используется для хранения String объектов, содержащих ссылки на эти изображения.В методе getView моего Adapter этот ArrayList используется, чтобы увидеть, какое изображение нужно показать.

Пока это работает нормально, но я столкнулся с проблемой, когда пользователь выбираетдругое изображение, чем первое изображение в GridView.Когда пользователь щелкает, например, 7-е изображение, Gallery показывает 7-е изображение.Но когда пользователь бросает вправо, чтобы увидеть предыдущие изображения (6-е изображение и ранее), ничего не происходит.Когда он бросается влево, чтобы увидеть предстоящие изображения, пользователю представляются 2-е элементы списка, затем 3-е, затем 4-е и т. Д.

Очевидно, Gallery считает, что любое изображение, которое я предоставляюон с первого, фактически является первым элементом в списке, и начинает показывать все после этого, как и должно быть, если изображение было на самом деле первым.Но Gallery должен показывать изображение как фактическое положение, в котором он находился GridView.Как я могу достичь чего-то подобного?Я пытался возиться с position, который я получаю при нажатии на GridView, но это просто приводит к поведению, которое я описал выше.

Вот код, который я использовал для этого:

PhotoFullView (галерея и адаптер для галереи)

package com.mobowski.appfrag.json.pictures;

import java.io.BufferedInputStream;
import java.io.InputStream;
import java.net.URL;
import java.net.URLConnection;
import java.util.ArrayList;

import com.mobowski.appfrag.R;

import android.app.Activity;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.view.Display;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Gallery;
import android.widget.ImageView;

public class PhotoFullView extends Activity {
    /** Called when the activity is first created. */
    CustomGallery gallery;
    public ArrayList<String> links;
    private int pos;

    @Override
    public void onCreate(Bundle icicle) {
        super.onCreate(icicle);
        setContentView(R.layout.full_photo_gallery);

        Bundle bun = getIntent().getExtras();
        links = bun.getStringArrayList("links");
        pos = bun.getInt("pos");

        /*
         * Find the gallery defined in the main.xml Apply a new (custom)
         * ImageAdapter to it.
         */
        gallery = (CustomGallery) findViewById(R.id.gallery);
        gallery.setAdapter(new ImageAdapter(this, links, pos));
        gallery.setSpacing(25);

    }

    public class ImageAdapter extends BaseAdapter {
        /** The parent context */
        private Context myContext;
        private ArrayList<String> links;
        int pos;

        Display display = getWindowManager().getDefaultDisplay();
        int width = display.getWidth();
        int height = display.getHeight();

        /**
         * All images to be displayed. Put some images to project-folder:
         * '/res/drawable/uvw.xyz' .
         */

        /** Simple Constructor saving the 'parent' context. */
        public ImageAdapter(Context c, ArrayList<String> links, int pos) {
            this.myContext = c;
            this.links = links;
            this.pos = pos;
        }

        /** Returns the amount of images we have defined. */
        public int getCount() {
            return this.links.size();
        }

        /* Use the array-Positions as unique IDs */
        public Object getItem(int position) {
            return position;
        }

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

        /**
         * Returns a new ImageView to be displayed, depending on the position
         * passed.
         */
        public View getView(int position, View convertView, ViewGroup parent) {
            ImageView i = new ImageView(this.myContext);

            String imageURL = links.get(position);
            if (position == 0) {
                imageURL = links.get(pos);
            }
            try {
                URL aURL = new URL(imageURL);
                URLConnection conn = aURL.openConnection();
                conn.connect();
                InputStream is = conn.getInputStream();
                /* Buffered is always good for a performance plus. */
                BufferedInputStream bis = new BufferedInputStream(is);
                /* Decode url-data to a bitmap. */
                Bitmap bm = BitmapFactory.decodeStream(bis);

                bis.close();
                is.close();
                /* Apply the Bitmap to the ImageView that will be returned. */
                i.setImageBitmap(bm);
            } catch (Exception e) {
                e.printStackTrace();
            }

            /* Image should be scaled as width/height are set. */
            // i.setScaleType(ImageView.ScaleType.FIT_XY);
            // /* Set the Width/Height of the ImageView. */
            // i.setLayoutParams(new Gallery.LayoutParams());
            return i;
        }

    }
}

Пользовательский класс галереи (используется для перегрузки onFling, так что он показывает только одно изображение за один раз)

package com.mobowski.appfrag.json.pictures;

import android.content.Context;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.widget.Gallery;

public class CustomGallery extends Gallery{

    public CustomGallery(Context context, AttributeSet attrs) {
        super(context, attrs);
        // TODO Auto-generated constructor stub
    }

    @Override
    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
      return super.onFling(e1, e2, 0, velocityY);
    }

}

Мне только что удалось выяснить, как правильно удерживать позицию при дальнейшей прокрутке после выбора пользовательского начального изображения, используя

String imageURL = links.get(pos+position);

, где pos - этоПоложение изображения кликнуло в GridView.Тем не менее, это по-прежнему не дает мне возможности прокручивать назад изображения до того, как изображение щелкнуло.


Ну, это было намного проще, чем я думал.После прочтения документации я обнаружил, что могу использовать setSelection(position) на моем Gallery объекте, чтобы начать с определенной позиции.Если бы все проблемы были так легко решить.Спасибо за чтение, хотя!

1 Ответ

7 голосов
/ 02 января 2012

Ну, это было намного проще, чем я думал.После прочтения документации я обнаружил, что могу использовать setSelection(position) на моем Gallery объекте, чтобы начать с определенной позиции.Если бы все проблемы были так легко решить.Спасибо за чтение, хотя!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...