Галерея Android с первым эскизом в качестве обложки - PullRequest
0 голосов
/ 13 апреля 2011

Спасибо за чтение!

Некоторый фон:

Я создаю приложение Gallery из учебника здесь

Единственное изменение, которое я внес в этот код, это замена

i.setLayoutParams(new Gallery.LayoutParams(150, 100));

с

i.setLayoutParams(new Gallery.LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT));

для отображения только одного изображения галереи за раз (вроде как просмотрщик слайд-шоу).

Проблема:

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

Эксперимент: Итак, я создал cover.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"
    android:padding="6dip">
    <ImageView android:id="@+cover/imgImage" android:adjustViewBounds="true"
        android:layout_width="fill_parent" android:layout_height="fill_parent">
    </ImageView>
    <TextView android:id="@+cover/tvCoverText1"
        android:layout_width="fill_parent" android:layout_height="wrap_content"
        android:maxLines="2" android:text="Text1" />
    <TextView android:id="@+cover/tvCoverText2"
        android:layout_width="fill_parent" android:layout_height="wrap_content"
        android:singleLine="true" android:maxLines="1" android:layout_below="@cover/tvCoverText1"
        android:text="Text2" />
</RelativeLayout>

А вот и код Java. Я проверяю в getView(), является ли позиция 0 (первая миниатюра), а затем играюсь с представлениями.


package com.sagar.sample;

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.LayoutInflater;
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 Main extends Activity {

    private LayoutInflater mInflater = null;

    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        Gallery g = (Gallery) findViewById(R.main.gallery);
        g.setAdapter(new ImageAdapter(this));

        g.setOnItemClickListener(new OnItemClickListener() {
            public void onItemClick(AdapterView parent, View v, int position, long id) {
                Toast.makeText(Main.this, "" + position, Toast.LENGTH_SHORT).show();
            }
        });
    }

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

        private Integer[] mImageIds = {
                0, R.drawable.bp1, R.drawable.bp2, R.drawable.bp3 
        };

        public ImageAdapter(Context c) {
            mContext = c;
            mInflater = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE);
//            TypedArray a = obtainStyledAttributes(R.styleable.HelloGallery);
//            mGalleryItemBackground = a.getResourceId(
//                    R.styleable.HelloGallery_android_galleryItemBackground, 0);
//            a.recycle();
        }

        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) {
            ViewHolder viewHolder;
            View view = convertView;
            if(view == null) {
                view = mInflater.inflate(R.layout.cover, null);

                viewHolder = new ViewHolder();
                viewHolder.tvCoverText1 = (TextView)view.findViewById(R.cover.tvCoverText1);
                viewHolder.tvCoverText2 = (TextView)view.findViewById(R.cover.tvCoverText2);
                viewHolder.imgView = (ImageView)view.findViewById(R.cover.imgImage);
                view.setTag(viewHolder);             
            }
            else {
                viewHolder = (ViewHolder)view.getTag();
            }

            if(position == 0) {
                viewHolder.tvCoverText1.setVisibility(View.VISIBLE);
                viewHolder.tvCoverText2.setVisibility(View.VISIBLE);
                viewHolder.imgView.setVisibility(View.GONE);
            }
            else {
                viewHolder.tvCoverText1.setVisibility(View.GONE);
                viewHolder.tvCoverText2.setVisibility(View.GONE);
                viewHolder.imgView.setVisibility(View.VISIBLE);
                //viewHolder.imgView = new ImageView(mContext);
                viewHolder.imgView.setImageResource(mImageIds[position]); //Album cover is at 0th position
                viewHolder.imgView.setLayoutParams(new Gallery.LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT));
                viewHolder.imgView.setScaleType(ImageView.ScaleType.FIT_XY);
                viewHolder.imgView.setBackgroundResource(mGalleryItemBackground);
            }
            return view;
        }
    }

    static class ViewHolder {
        TextView tvCoverText1, tvCoverText2;
        ImageView imgView;
    }
}

Конечный результат: Когда приложение загружается, я сначала некоторое время вижу пустой экран, а затем вид меняется, чтобы отобразить AlbumCover. И это очень медленно прокручивать изображения.

Хм .. Очевидно, я делаю что-то не так. Я искренне надеюсь, что кто-то может помочь мне здесь: (

Спасибо!

ОБНОВЛЕНИЕ: Добавление main.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="@+main/gallery"
        android:layout_width="fill_parent" android:layout_height="fill_parent"
    />
</RelativeLayout>

ОБНОВЛЕНИЕ 2: Итак, вот некоторый код psuedo, чтобы объяснить, чего я пытаюсь достичь:


if(position == 0)
    //show toptext and bottomtext from cover.xml
else
    //show tvTitle1 and tvTitle2 (may later include tvTitle3 and tvTitle4) from main.xml

Прямо сейчас, работает только случай позиции 0, и это также, когда я проведу пальцем в положение 1 и проведу пальцем назад в положение 0 - TextView s выделены серым цветом и едва заметны (

Ответы [ 3 ]

0 голосов
/ 14 апреля 2011

У вас, вероятно, должен быть 1 единственный файл макета, который содержит компоненты пользовательского интерфейса в галерее. Прямо сейчас у вас есть 2 TextView компонентов, которые не зависят от Gallery. Вместо этого создайте некоторый ресурс макета как это: gallery_item.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">
<ImageView
    android:id="@+id/imageView"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:adjustViewBounds="true"
    android:background="@android:drawable/picture_frame"
    android:layout_centerInParent="true" />
    <TextView 
        android:id="@+main/tvTitle1" android:text="Title 1"
        android:layout_width="wrap_content" android:layout_height="wrap_content"
        android:layout_above="@+main/tvTitle2">
    </TextView>
    <TextView  
        android:id="@+main/tvTitle2" android:text="Title 2"
        android:layout_width="wrap_content" android:layout_height="wrap_content"
        android:layout_alignParentBottom="true" android:layout_alignParentLeft="true">
     </TextView>
</RelativeLayout>

Так в вашем getView:

        View v = convertView;
        if(v == null) {
            LayoutInflater vi = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            v = vi.inflate(R.layout.gallery_item, null);

            holder = new ViewHolder();
            holder.text1 = (TextView)v.findViewById(R.id.tvTitle1);
            holder.text2 = (TextView)v.findViewById(R.id.tvTitle2);
            holder.imageView = (ImageView)v.findViewById(R.id.imageView);

            v.setTag(holder);
        }
        else
            holder = (ViewHolder)v.getTag();

        if(position == 0) {
          holder.text1.setVisibility(View.VISIBLE);
          holder.text2.setVisibility(View.VISIBLE);
          holder.imageView.setVisibility(View.GONE);
        }
        else {
          holder.text1.setVisibility(View.GONE);
          holder.text2.setVisibility(View.GONE);
          holder.imageView.setVisibility(View.VISIBLE);
        }

        return v;

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

((TextView)v.findViewById(R.id.tvTitle1)).setVisibility(View.GONE); и т. Д.

Вам также может быть интересно установить различные типы представлений для getView: http://developer.android.com/reference/android/widget/Adapter.html#getItemViewType(int)

0 голосов
/ 20 апреля 2011

Попробовав все предложенные здесь подходы, я так и не смог получить собственную галерею так, как хотел.Я продолжал сталкиваться с ClassCastException.Итак, вот , что работало для меня до сих пор.Это всего лишь обходной путь, и в случае, если кто-то придумает лучший способ создать собственную галерею, оставьте здесь свой ответ, чтобы я мог принять его.

Спасибо за помощь!

0 голосов
/ 13 апреля 2011

Вы должны устанавливать текст в ваших текстовых представлениях каждый раз, а не только при расширении представления.

...