андроид круговая галерея? - PullRequest
       34

андроид круговая галерея?

5 голосов
/ 03 сентября 2010

Я новичок в разработке для Android. Теперь я хотел бы сделать просмотр галереи в виде кругового изображения, как показано ниже. Дело в том, что я хочу увеличить центральное изображение, когда пользователь выполняет прокрутку слева направо и справа налево. Есть ли уроки для этого?

enter image description here я хочу, чтобы изображение, которое было проведено, нужно было увеличить, пока оно находится в центре. Я думал, что смогу сделать это с Галереей. но пример от разработчика Android не тот, который я хочу. (

Ответы [ 3 ]

12 голосов
/ 03 сентября 2010

Вы можете попробовать:

public class TestGallery extends Activity {
/** Called when the activity is first created. */
private Integer[] mImageIds = { R.drawable.sample_1, R.drawable.sample_2, R.drawable.sample_3, R.drawable.sample_4 }; 

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    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) { 
            if (position >= mImageIds.length) { 
                position = position % mImageIds.length; 
            } 
            Toast.makeText(TestGallery.this, "" + position, Toast.LENGTH_SHORT).show(); 
        } 
    }); 

}

public class ImageAdapter extends BaseAdapter { 
    int mGalleryItemBackground; 
    private Context mContext; 

    public ImageAdapter(Context c) { 
        mContext = c; 
        TypedArray a = obtainStyledAttributes(R.styleable.Gallery1); 
        mGalleryItemBackground = a.getResourceId(R.styleable.Gallery1_android_galleryItemBackground, 0); 

        a.recycle(); 
    } 

    public int getCount() { 
        return Integer.MAX_VALUE; 
    } 

    public Object getItem(int position) { 
        if (position >= mImageIds.length) { 
            position = position % mImageIds.length; 
        } 
        return position; 
    } 

    public long getItemId(int position) { 
        if (position >= mImageIds.length) { 
            position = position % mImageIds.length; 
        } 
        return position; 
    } 

    public View getView(int position, View convertView, ViewGroup parent) { 
        ImageView i = new ImageView(mContext); 
        if (position >= mImageIds.length) { 
            position = position % mImageIds.length; 
        } 
        i.setImageResource(mImageIds[position]); 
        i.setLayoutParams(new Gallery.LayoutParams(80, 80)); 
        i.setScaleType(ImageView.ScaleType.FIT_XY); 
        i.setBackgroundResource(mGalleryItemBackground); 
        return i; 
    } 

    public int checkPosition(int position) { 
        if (position >= mImageIds.length) { 
            position = position % mImageIds.length; 
        } 
        return position; 
    } 
}}
5 голосов
/ 25 сентября 2010


Если вы хотите увеличить выбранное по центру изображение, есть один из возможных способов.В вашем методе onItemSelected просто вызовите анимацию для масштабирования объекта.Свойство галереи в том, что она всегда в центре.Таким образом, центральный элемент будет всегда выбран.Надеюсь, что это сработает ..

<?xml version="1.0" encoding="utf-8"?>
<set
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shareInterpolator="false"
    android:fillAfter="true"
>
<scale 
       android:fromXScale="1.0"
       android:toXScale="1.50"
       android:fromYScale="1.0"
       android:toYScale="1.50"
       android:duration="600"
       android:pivotX="50%"
       android:pivotY="50%"
       android:fillAfter="true"/>

</set>

Помните, что вам нужно будет сохранить предыдущее представление, так как, когда элемент перемещается от центра, он должен иметь нормальный размер.

Таким образом, вы можете иметь два вида - prevView и currView.
Выполните анимацию на currView.

Спасибо,
Сен

1 голос
/ 02 августа 2011

Я создал свой собственный учебник для этого: http://evgeni -shafran.blogspot.com / 2011/08 / учебник-заказ галерея-круговым and.html

Чтобы оно было круглым, нужно заставить его думать, что у него МНОГО элементов, гораздо больше, чем у вас есть на самом деле.

И затем, сделав position = position% items.length, вы создадите что-то вроде (я покажу это для 3 элементов): 1,2,3,1,2,3,1,2,3,1,2, 3,1,2,3,1,2,3,1,2,3 А затем перейдите к середине, поэтому, даже если свиток много, он не приблизится к концу. 1,2,3,1,2,3,1,2,3, -> 1

Чтобы он был выбран: вам нужно переопределить setOnItemSelectedListener и манипулировать размером. не забудьте сохранить ссылку на ваш последний вид, чтобы при переходе к следующему вы могли сделать так, чтобы он выглядел обычным, а не увеличенным.

Я реализовал это в моем уроке, указанном выше

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