Я создаю раздел галереи для своего приложения, который будет использоваться для отображения количества изображений 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
объекте, чтобы начать с определенной позиции.Если бы все проблемы были так легко решить.Спасибо за чтение, хотя!