-1

こんにちは、みんな!!グリッドビューに画像を表示しました。グリッドビューの画像をクリックすると、クリックした画像が画面に表示された次のページに移動します。必要に応じて、画像の説明を全画面に追加する必要があります。 TextView を取得しました しかし、それは起こっていません.Hereは私のコードです...

FullImage.java

public class FullImage extends Activity {
private TextView lView = null;
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.full);

    // get intent data
    Intent i = getIntent();

    // Selected image id
    int position = i.getExtras().getInt("id");

    if (position == 1){
        lView = (TextView)findViewById(R.id.my_title);
        lView.setText("Akshardham");

    }
    else{
        lView = (TextView)findViewById(R.id.my_title);
        lView.setText("Other");

    }



    ImageAdapter imageAdapter = new ImageAdapter(this);

    ImageView imageView = (ImageView) findViewById(R.id.full_image_view);
    imageView.setImageResource(imageAdapter.mThumbIds[position]);
}

そしてFull.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >

<ImageView android:id="@+id/full_image_view"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"/>

<TextView
android:id="@+id/my_title"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:layout_centerVertical="true"
android:layout_marginLeft="5dip"/>

そして、これが私のメインアクティビティクラスのコードです..

gridView.setOnItemClickListener(new OnItemClickListener() {
        @Override
        public void onItemClick(AdapterView<?> parent, View v,
                int position, long id) {

            // Sending image id to FullScreenActivity
            Intent i = new Intent(getApplicationContext(), FullImage.class);
            // passing array index
            i.putExtra("id", position);
            startActivity(i);
        }
    });
}

そして、これが私のImageAdapterコードです...

public class ImageAdapter extends BaseAdapter {
private Context mContext;

// Keep all Images in array
public Integer[] mThumbIds = {
        R.drawable.akshar, R.drawable.charminar,
        R.drawable.gateway, R.drawable.goa,
        R.drawable.jimcorbet, R.drawable.kerala,
        R.drawable.mussoorie, R.drawable.parliament,
        R.drawable.qutub, R.drawable.taj,
        R.drawable.tirupati

};

// Constructor
public ImageAdapter(Context c){
    mContext = c;
}

@Override
public int getCount() {
    return mThumbIds.length;
}

@Override
public Object getItem(int position) {
    return mThumbIds[position];
}

@Override
public long getItemId(int position) {
    return 0;
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {
    ImageView imageView = new ImageView(mContext);
    imageView.setImageResource(mThumbIds[position]);
    imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
    imageView.setLayoutParams(new GridView.LayoutParams(270, 270));
    return imageView;
}

}

4

1 に答える 1

1

ここで、imageView は高さと幅の塗りつぶしの親であるため、画面で使用可能なすべてのスペースを使用しています。そのため、両方の要素を順番に表示するようにレイアウトを設計する必要があります。

<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <ImageView
        android:id="@+id/full_image_view"
        android:layout_width="fill_parent"
        android:src="@drawable/button"
        android:layout_height="wrap_content" />

    <TextView
        android:id="@+id/my_title"
        android:layout_centerHorizontal="true"
        android:layout_below="@+id/full_image_view"
        android:layout_height="wrap_content"
        android:text="This is the image which i want at bottom"
        android:layout_width="wrap_content"
        android:layout_marginLeft="5dip" />
</RelativeLayout>
于 2013-03-12T05:03:20.463 に答える