0

我正在尝试制作一个简单的应用程序来显示图片。图像被缩放以适合屏幕,然后图像下方有一个下一个和上一个按钮。我希望下一个和上一个按钮位于按钮上,但它们不断被绘制在图像的按钮上。因此,每次显示新图像时,它们都会根据图片的大小上下移动。

我在这里找到了以下解决方案,但它对我不起作用:

android:gravity="bottom"  
android:layout_alignParentBottom="true"

这是xml文件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/backFeetGallery"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <ImageView
        android:id="@+id/viewimage"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:src="@drawable/background" />

    <LinearLayout
        android:id="@+id/linearLayout4"
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:gravity="bottom"
        android:orientation="horizontal" >

        <Button
            android:id="@+id/butLeft"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_marginTop="12px"
            android:text=" Left "
            android:textColor="#ff0000ff" />

        <Button
            android:id="@+id/butFavrest"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_marginTop="12px"
            android:text=" Favrets "
            android:textColor="#ff0000ff" />

        <Button
            android:id="@+id/butEmail"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_marginTop="12px"
            android:text=" email "
            android:textColor="#ff0000ff" />

        <Button
            android:id="@+id/butRight"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_marginTop="12px"
            android:text=" Right "
            android:textColor="#ff0000ff" />
    </LinearLayout>

</LinearLayout>

源代码

public class cFeetView extends cBaseView implements OnClickListener {
    cFileNames mFileNames;

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

        // add listeners
        View mLeft = findViewById(R.id.butRight);
        mLeft.setOnClickListener(this);

        // add listeners
        View mRight = findViewById(R.id.butLeft);
        mRight.setOnClickListener(this);

        mFileNames=new cFileNames();
        mFileNames.Start();
        DrawFeet();
    }

    public void DrawFeet()
    {
        int screenHeight;
        ImageView picImage = (ImageView) findViewById(R.id.viewimage);// R.id.viewpic);
        try {
            String FileName = "canon20.png";
            FileName=mFileNames.Current();
            AssetManager assetManager = getAssets();
            InputStream inputStream;
            inputStream = assetManager.open(FileName);
            Bitmap icon = BitmapFactory.decodeStream(inputStream);

            int screenWidth = getWindowManager().getDefaultDisplay().getWidth();
            screenHeight = getWindowManager().getDefaultDisplay().getHeight();

            int bw = icon.getWidth();
            int bh=icon.getHeight();
            float t = (float) screenWidth / (float) bw;

            int iConHeight=(int)((float)bh*t);
            picImage.setImageBitmap(icon);

            // scale it
            picImage.getLayoutParams().width = screenWidth;
            picImage.getLayoutParams().height =iConHeight;
            Bitmap scaledIcon = Bitmap.createScaledBitmap(icon, screenWidth, iConHeight, false);

        } catch (IOException e) {
        }
    }
    // set the top and buttom margins

    public void onClick(View v)
    {
        Intent i;
        switch(v.getId())
        {
        case R.id.butLeft:
            mFileNames.Pre();   
            DrawFeet();
            break;
        case R.id.butRight:
            mFileNames.Next();
            DrawFeet();
            break;              
        }
    }
} // end class
4

3 回答 3

2

Instead of LinearLayout, use RelativeLayout in your xml file.

LinearLayout is used only to arrange them in horizontal or vertical directions.

于 2012-08-29T07:20:49.830 回答
0

为了使用 alignParentBottom,您需要使用 RelativeLayout。而且你不需要重力属性。

我对您的特定场景的建议是您有一个 RelativeLayout 并将所有按钮放在一个底部对齐的 LinearLayout 和其上方的 ImageView 中。

伪:

<RelativeLayout>
   <ImageView />

   <LinearLayout
      android:layout_below="@ImageView_id"
      android:layout_alignParentBottom=true>
   </LinearLayout>
</RelativeLayout>

Edited with your xml:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/backFeetGallery"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <ImageView
        android:id="@+id/viewimage"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:src="@drawable/background" />

    <LinearLayout
        android:id="@+id/linearLayout4"
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:layout_below="@id/viewimage"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:orientation="horizontal" >

        <Button
            android:id="@+id/butLeft"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_marginTop="12px"
            android:text=" Left "
            android:textColor="#ff0000ff" />

        <Button
            android:id="@+id/butFavrest"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_marginTop="12px"
            android:text=" Favrets "
            android:textColor="#ff0000ff" />

        <Button
            android:id="@+id/butEmail"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_marginTop="12px"
            android:text=" email "
            android:textColor="#ff0000ff" />

        <Button
            android:id="@+id/butRight"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_marginTop="12px"
            android:text=" Right "
            android:textColor="#ff0000ff" />
    </LinearLayout>

</RelativeLayout>
于 2012-08-28T23:32:08.503 回答
0

You need to have everything in RelativeLayout. For example, look at this sample code which I made for one button which is aligned to bottom center of screen.

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

<Button
    android:id="@+id/button1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_centerHorizontal="true"
    android:text="Button" />

And here is the complete layout file for your layout

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

<Button
    android:id="@+id/button2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:text="Button" />

<Button
    android:id="@+id/button4"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_alignParentLeft="true"
    android:text="Button" />

<Button
    android:id="@+id/button3"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_alignParentRight="true"
    android:text="Button" />

<Button
    android:id="@+id/button1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_toRightOf="@+id/button2"
    android:text="Button" />

<Button
    android:id="@+id/button5"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_toLeftOf="@+id/button3"
    android:text="Button" />

<ImageView
    android:id="@+id/imageView1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentTop="true"
    android:layout_centerHorizontal="true"
    android:layout_marginTop="38dp"
    android:src="@android:drawable/gallery_thumb" />

This is how it looks, enter image description here

于 2012-08-28T23:38:16.643 回答