ギャラリーを作成しています。すべての画像を表示する gridlayout があります。ある画像を選択すると、別のインテントが開始されますが、この新しいインテントで選択した画像を表示したいと思います。
事前に感謝します。
ギャラリーを作成しています。すべての画像を表示する gridlayout があります。ある画像を選択すると、別のインテントが開始されますが、この新しいインテントで選択した画像を表示したいと思います。
事前に感謝します。
以下のグリッドビューのコードを使用してください。
main.xml
<?xml version="1.0" encoding="utf-8"?>
<GridView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/gridview"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:columnWidth="90dp"
android:numColumns="auto_fit"
android:verticalSpacing="10dp"
android:horizontalSpacing="10dp"
android:stretchMode="columnWidth"
android:gravity="center" />
ImageAdapter.java
public class ImageAdapter extends BaseAdapter {
private Context mContext;
public ImageAdapter(Context c) {
mContext = c;
}
public int getCount() {
return mThumbIds.length;
}
public Object getItem(int position) {
return null;
}
public long getItemId(int position) {
return 0;
}
// create a new ImageView for each item referenced by the Adapter
public View getView(int position, View convertView, ViewGroup parent) {
ImageView imageView;
if (convertView == null) { // if it's not recycled, initialize some attributes
imageView = new ImageView(mContext);
imageView.setLayoutParams(new GridView.LayoutParams(85, 85));
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
imageView.setPadding(8, 8, 8, 8);
} else {
imageView = (ImageView) convertView;
}
imageView.setImageResource(Constants.mThumbIds[position]);
return imageView;
}
}
定数.java
public class Constants {
// references to our images
private Integer[] mThumbIds = {
R.drawable.sample_2, R.drawable.sample_3,
R.drawable.sample_4, R.drawable.sample_5,
R.drawable.sample_6, R.drawable.sample_7,
R.drawable.sample_0, R.drawable.sample_1,
R.drawable.sample_2, R.drawable.sample_3,
R.drawable.sample_4, R.drawable.sample_5,
R.drawable.sample_6, R.drawable.sample_7,
R.drawable.sample_0, R.drawable.sample_1,
R.drawable.sample_2, R.drawable.sample_3,
R.drawable.sample_4, R.drawable.sample_5,
R.drawable.sample_6, R.drawable.sample_7
};
}
MainActivity.java
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
GridView gridview = (GridView) findViewById(R.id.gridview);
gridview.setAdapter(new ImageAdapter(this));
gridview.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView<?> parent, View v, int position, long id) {
Intentt mInDisplay=new Intent(MainActivity.this, DisplayActivity.class);
mInDisplay.putExtra("Index", position);
startActivity(mInDisplay);
}
});
}
}
display.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/mImgView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</RelativeLayout>
DisplayActivity.java
public class DisplayActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Bundle bdl=getIntent().getExtras();
int index=bdl.getInt("Index");
ImageView mImage = (ImageView) findViewById(R.id.mImgView1);
mImage.setImageResource(Constants.mThumbIds[index]);
}
}
両方のアクティビティを Android マニフェスト ファイルに宣言します。
setOnClickListenerを使用して、すべての画像にクリック リスナーを設定できます。リスナーは、新しいアクティビティを開始するインテントを送信できます。
また、インテントとともに画像パスを送信したいと考えています。これを実現するには 、最初のパラメーターとして選択した名前と 2 番目のパラメーターとしてイメージ パスを使用して、インテントでputExtraを使用できます。
その後、新しいアクティビティでgetStringExtraを使用して画像パスを取得できるはずです。アクティビティで getIntent() を呼び出してインテントを取得する必要があります
幸運を