动态地将图像视图添加到水平滚动(通过代码)

时间:2017-01-03 10:17:20

标签: android android-studio horizontalscrollview

我刚刚开始研究android,我正在研究卷轴。我已经做了一个,但我现在想动态地做同样的事情。

这是我的activity_main.xml

的代码
<HorizontalScrollView
    android:id="@+id/horizontalScrollView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:scrollbars="horizontal">

    <LinearLayout
        android:id= "@+id/linearlayout1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:onClick="onTouch">


    </LinearLayout>

</HorizontalScrollView>




<LinearLayout
    android:id="@+id/bottomlinear"
    android:layout_width="match_parent"
    android:layout_height="400px"
    android:gravity="center"
    android:background="#00ffff"
    android:orientation="vertical"
    android:layout_alignParentBottom="true"
    android:layout_alignParentLeft="true"
    android:layout_alignParentStart="true"
    android:layout_marginBottom="46dp">>
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/drop"
        android:textSize="30sp"
        android:text="Drop Zone" />
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/Total"
        android:textSize="20sp" />
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/Success"
        android:textSize="20sp" />
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/Fail"
        android:textSize="20sp" />

</LinearLayout>

基本上我想将可绘制的10个图像动态添加到水平滚动中作为图像视图。任何帮助或想法都非常感谢。

4 个答案:

答案 0 :(得分:3)

你可以这样做。

  1. 创建一个包含imageView的xml布局。
  2. image_item.xml

     <ImageView
    
                xmlns:android="http://schemas.android.com/apk/res/android"
                xmlns:app="http://schemas.android.com/apk/res-auto"
                android:layout_width="200dp"
                android:layout_height="200dp"
                android:visibility="visible"
                android:adjustViewBounds="true"
            />
    
    1. 现在找到想要进入java文件的容器,就像这样。

      LinearLayout containerLayout = (LinearLayout)findViewById(R.id.linearlayout1);
      
    2. 现在只需运行for循环直到10并在运行时添加视图。

           for(int a = 0 ; a < 10 ; a++)
          {
              LayoutInflater inflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);
              View inflatedView = inflater.inflate(R.layout.image_item, null);
              containerLayout.addView(inflatedView);
          }
      
    3. 希望这有帮助,随意讨论是否发现问题。

      快乐编码: - )

答案 1 :(得分:1)

我解决了这个问题。我要发布解决方案,希望它可以帮助其他人遇到类似的问题。我最初制作了3个水平滚动视图,其中一个的xml就像这样

    <HorizontalScrollView
    android:id="@+id/HorizontalScrollView1"
    android:layout_width="match_parent"
    android:layout_height="100dp"
    android:layout_marginBottom="1dp"
    android:background="#FFF"
    android:scrollbars="none">

    <LinearLayout
        android:id="@+id/imgLayout1"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:orientation="horizontal">

    </LinearLayout>


</HorizontalScrollView>

我编写的代码用于在水平滚动视图的线性布局中创建图像视图:

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

   for (int j=1; j<=10; j++)
    {
        b1=j;
        create_img1("drawable/a"+j, b1);
    }


}

void create_img1(String ss, int ID)
{
    LinearLayout linearLayout = (LinearLayout) findViewById(R.id.imgLayout1);
    LinearLayout.LayoutParams parms = new LinearLayout.LayoutParams(200, 200);
    parms.gravity = Gravity.CENTER;
    parms.setMargins(20, 20, 20, 20);
    final ImageView imageView = new ImageView(this);
    imageView.setLayoutParams(parms);

    int id = getResources().getIdentifier(ss, "id", getPackageName());
    imageView.setImageResource(id);
    linearLayout.addView(imageView);
    imageView.setId(ID);
}

我使用拖放功能为多个滚动视图制作了一个,但是我将其过滤掉了,如果你想动态地在滚动视图中创建图像视图,这就是你要找的东西。希望这可以帮助其他有类似问题的人。

答案 2 :(得分:0)

我认为你正在尝试做这样的事情:

mHScrollContentView = (ViewGroup) findViewbyId(R.id.linearlayout1);

ImageView iv1 = new ImageView(this);
iv.setImageResource(R.drawable.image_1);

ImageView iv2 = new ImageView(this);
iv.setImageResource(R.drawable.image_2);

ImageView iv3 = new ImageView(this);
iv.setImageResource(R.drawable.image_3);

ImageView iv4 = new ImageView(this);
iv.setImageResource(R.drawable.image_4);

mHScrollContentView.addView(iv1);
mHScrollContentView.addView(iv2);
mHScrollContentView.addView(iv3);
mHScrollContentView.addView(iv4);

答案 3 :(得分:0)