ورود

View Full Version : ساخت gridview



zarabela
شنبه 07 تیر 1393, 22:43 عصر
سلام

من میخوام یه grid view بسازم که آیتم هاش عکس باشن و با کلیک روی هر عکس یه صفحه جدید باز شه ... هر جا هم گشتم نتوستم طرز ساختش رو پیدا کنم :ناراحت:

کسی میتونه در حد مبتدی کمکم کنه؟

SASAN_AH
شنبه 07 تیر 1393, 23:23 عصر
سلام
بفرمایید
توضیحاتی که دادم بخون بلد میکنی که کار هر کد چی بوده!
امیدوارم کامل باشه!

اول فایل لایوتش رو درست میکنیم

activity_main.xml


<?xml version="1.0" encoding="utf-8"?><GridView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/grid_view"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:numColumns="auto_fit"
android:verticalSpacing="10dp"
android:horizontalSpacing="10dp"
android:columnWidth="90dp"
android:stretchMode="columnWidth"
android:gravity="center"/>


بعد کد مربوط به جاواش رو مینویسیم که برای هر تصویر با کلیک چه اتفاقی بیفته


MainActivity.java



import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;

public class MainActivity extends Activity {

private Context context;
\\ این عکس ها هست من اینجا 2 تا گذاشتم
private Integer[] mThumbIds = { R.drawable.icon, R.drawable.icon, };

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

\\ اینجا ایدی گرید ویو رو معرفی میکنیم
GridView gridview = (GridView) findViewById(R.id.grid_view);
\\اینجا هم گریدئ ویو رو ست میکنیم به اداپتور تا مقادیر رو بگیره
gridview.setAdapter(new ImageAdapter(this));
\\ خب اینم دستورات این هست که با کلیک روی هر عکس چه اتفاقی بیوفته
gridView.setOnItemClickListener(new OnItemClickListener()
{
@Override
public void onItemClick(AdapterView<?> parent, View v,
int position, long id) {

switch (position) {
case 0:
Toast.makeText(getApplicationContext(),"عکس اول", Toast.LENGTH_LONG).show();
break;
case 1:
Toast.makeText(getApplicationContext(),"عکس دوم", Toast.LENGTH_LONG).show();
break;
default:
break;
}
}
});
}

\\ این آداپتور گرید ویو هست که از BaseAdapter ارث بره شده
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;
}
\\ اینجا کارش تنظیم اینه که گرید ویو چه شکلی باشه
\\یعنی فاصله هر عکس یا شکل هر عکس چطور باشه
public View getView(int position, View convertView, ViewGroup parent) {
ImageView imageView;
if (convertView == null) {
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(mThumbIds[position]);
return imageView;
}
}

rubiks.kde
شنبه 07 تیر 1393, 23:31 عصر
سلام

من میخوام یه grid view بسازم که آیتم هاش عکس باشن و با کلیک روی هر عکس یه صفحه جدید باز شه ... هر جا هم گشتم نتوستم طرز ساختش رو پیدا کنم :ناراحت:

کسی میتونه در حد مبتدی کمکم کنه؟

دوست عزیز همه جا رو گشتید؟
این توی نمونه برنامه ها هست (http://barnamenevis.org/showthread.php?401729-%D9%86%D9%85%D9%88%D9%86%D9%87-%D8%A8%D8%B1%D9%86%D8%A7%D9%85%D9%87-%D9%87%D8%A7%DB%8C-%DA%A9%D9%88%DA%86%DA%A9-%D9%88-%D9%85%D9%81%D9%8A%D8%AF-%D8%A7%D9%86%D8%AF%D8%B1%D9%88%DB%8C%D8%AF&p=1969597&viewfull=1#post1969597)

zarabela
یک شنبه 08 تیر 1393, 01:47 صبح
ممنون از راهنماییتون ... فقط روی این قسمتا ارور میده:
private integer[] mThumbIds={R.drawable.attachment1,R.drawable.attac hment2,
R.drawable.baby,R.drawable.baby2,
};
خطا:Type mismatch: cannot convert from int to R.integer


و اینجا :
imageView.setImageResource(mThumbIds[position]);
خطا:The method setImageResource(int) in the type ImageView is not applicable for the arguments (R.integer)

SASAN_AH
یک شنبه 08 تیر 1393, 08:40 صبح
این رو


private integer[] mThumbIds={
R.drawable.attachment1,R.drawable.attachment2,
R.drawable.baby,R.drawable.baby2,};

با این تغییر بده


public Integer[] mThumbIds={
R.drawable.attachment1,R.drawable.attachment2,
R.drawable.baby,R.drawable.baby2,};