0

我被困在gridview。我想要一个 Gridview 下面的 imageview 来处理它的点击事件。基本上我需要的是当点击这个imageview按钮(这里是imageView_uparrow)时,它会向上滑动包含这个gridview的布局,但是当我在xml中的gridview(imageView_uparrow)下面添加imageview(imageView_uparrow)并运行项目时;gridview 在每个网格图标上重复该 imageview。我希望该图像视图在底部出现一次。这是我的 XML。

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:layout_gravity="top" >

    <GridView
        android:id="@+id/inside_gridView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="50dp"
        android:layout_marginLeft="14dp"
        android:layout_marginRight="14dp"
        android:layout_marginTop="58dp"
        android:alpha="0.1"
        android:background="#696969"
        android:columnWidth="10dp"
        android:gravity="center"
        android:numColumns="3"
        android:padding="4dp"
        android:scrollbars="vertical"
        android:stretchMode="columnWidth" >
    </GridView>

    <ImageView
        android:id="@+id/image_insidegrid"
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:layout_margin="5dp"
        android:contentDescription="@string/hello_world" />

    <ImageView
        android:id="@+id/imageView_uparrow"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_marginBottom="22dp"
        android:layout_marginRight="20dp"
        android:contentDescription="@string/hello_world"
        android:src="@drawable/drop_down_top_arrow" />

</RelativeLayout>

最后一个 imageview 即 imageView_uparrow 继续与 gridview 项目重复。请帮帮我..提前谢谢.!

4

1 回答 1

1

嘿,我得到了解决方案.. 我将 imageView_uparrow 保存在单独的 xml 和图像中,我曾经将其设置为我的网格单独 xml 的图标。然后膨胀并将其添加到布局中。

我修改后的 Grid Xml 在这里

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:layout_gravity="top"
    android:id="@+id/parentRel"
    >

    <GridView
        android:id="@+id/inside_gridView"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_marginBottom="50dp"
        android:layout_marginLeft="14dp"
        android:layout_marginRight="14dp"
        android:layout_marginTop="42dp"
        android:background="@drawable/transperant_background"
        android:gravity="center"
        android:numColumns="3"
        android:padding="0dp"
        android:scrollbars="vertical"
         >
    </GridView>

</RelativeLayout>

这是我的 ImageView(imageView_uparrow) 的 xml 文件。

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/layout_up_arrow_for_gridView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" >

    <ImageView
        android:id="@+id/imageview_up_arrow"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="14dp"
        android:contentDescription="@string/app_name"

         />

</RelativeLayout>

我用来膨胀的代码

Context context;
RelativeLayout rel;
ImageView upArrowImage;

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





        context=this;
    View grid2;

    rel=(RelativeLayout)findViewById(R.id.parentRel);

    animate = AnimationUtils.loadAnimation(this, R.anim.slide_up);
    animate.setAnimationListener(this);



    LayoutParams lp = new LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT);
    lp.setMargins(14, 400, 0, 20);



    grid2=new View(context);
    grid2=inflator.inflate(R.layout.gridview_up_arrow_button,null);

    upArrowImage=(ImageView)grid2.findViewById(R.id.imageview_up_arrow);

    ((ViewGroup)upArrowImage.getParent()).removeView(upArrowImage);

    rel.addView(upArrowImage);
    upArrowImage.setImageResource(R.drawable.drop_down_arrow4);
    upArrowImage.setLayoutParams(lp);
于 2012-08-30T12:52:48.693 回答