ImageAdapter带有自定义按钮

时间:2013-01-27 09:32:38

标签: java android gridview uibutton

我希望带有ImageAdapter的GridView具有自定义按下的按钮。我已经有自定义按钮,但onClick它会在按钮周围创建一个大的橙色onClick事物。我只想在onClick上显示我的自定义按下按钮。我应该如何轻松地做到这一点?

ImageAdapter:

public class ImageAdapter extends BaseAdapter {
private Context context;
private final String[] buttonValues;

public ImageAdapter(Context context, String[] buttonValues) {
    this.context = context;
    this.buttonValues = buttonValues;
}

public View getView(int position, View convertView, ViewGroup parent) {

    LayoutInflater inflater = (LayoutInflater) context
        .getSystemService(Context.LAYOUT_INFLATER_SERVICE);

    View gridView;

    if (convertView == null) {

        gridView = new View(context);

        // get layout from mobile.xml
        gridView = inflater.inflate(R.layout.mobile, null);


        // set image based on selected text
        ImageView imageView = (ImageView) gridView
                .findViewById(R.id.grid_item_image);

        String button = buttonValues[position];



        if (button.equals("homework")) {
            imageView.setImageResource(R.drawable.homework);
        } else if (button.equals("schedule")) {
            imageView.setImageResource(R.drawable.button_schedule);
        } else if (button.equals("planner")) {
            imageView.setImageResource(R.drawable.plannerbut);
        } else {
            imageView.setImageResource(R.drawable.settingsbut);
        }

    } else {
        gridView = (View) convertView;
    }

    return gridView;
}

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

@Override
public Object getItem(int position) {
    return null;
}

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

}

我的Activity(GridView方法):

private void setGridView() {
    gridView = (GridView) findViewById(R.id.gridView1);

    gridView.setAdapter(new ImageAdapter(this, MOBILE_OS));

    gridView.setOnItemClickListener(new OnItemClickListener() {
        public void onItemClick(AdapterView<?> parent, View v,
                int position, long id) {
            switch (position) {
            case 0:
                Toast.makeText(getApplicationContext(), "homework", Toast.LENGTH_SHORT).show();
                break;
            case 1:
                Toast.makeText(getApplicationContext(), "schedule", Toast.LENGTH_SHORT).show();
                break;

            case 2:
                Toast.makeText(getApplicationContext(), "planner",
                        Toast.LENGTH_SHORT).show();
                break;

            case 3:
                Toast.makeText(getApplicationContext(), "settings",
                        Toast.LENGTH_SHORT).show();
                break;
            }

        }
    });

}

提前致谢!

的Wouter

2 个答案:

答案 0 :(得分:1)

您可以让按钮使用自定义绘图,您可以自己定义不同的状态。

<Button
    android:id="@+id/mybutton"
    android:background="@drawable/custom_button_selector" />

custom_button_selector.xml:

<?xml version="1.0" encoding="utf-8"?> 
<selector xmlns:android="http://schemas.android.com/apk/res/android"> 
    <item android:state_focused="true" android:state_pressed="true" 
        android:drawable="@drawable/bg_pressed" /> 
    <item android:state_focused="false" android:state_pressed="true" android:drawable="@drawable/bgalt" /> 
    <item android:drawable="@drawable/bg_normal" /> 
</selector>

然后在bg_pressed / normal中定义不同的按钮。

查看http://www.mkyong.com/android/android-imagebutton-selector-example/

答案 1 :(得分:0)

我通过在gridview中添加ListSelector并在ImageAdapter中添加选择器来修复它。