如何在android中的按钮之间画线

时间:2014-07-06 19:40:00

标签: java android

我想在两个按钮的中间点之间绘制线。我创建了使用下面的代码我在我的Android模拟器中检查它是否正常工作。我把那个apk放到我的手机但这些线不在正确的位置。
如何在两个按钮的两个中间点之间定位线?
它适用于每个屏幕尺寸不同的Android手机
这就是我想画线的方式 ![IMG] http://i58.tinypic.com/1o7hj9.png[/IMG] android emulator http://i58.tinypic.com/1o7hj9.png

// activity_main.xml中

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >

    <RelativeLayout
        android:id="@+id/rl1"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:background="#ffffaa" >
    </RelativeLayout>

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical" 
        android:id="@+id/linearLayout1">
    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal" >
    <Button
        android:layout_weight="1"
        android:id="@+id/bx1y1"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:text="" />
    <Button
        android:layout_weight="1"
        android:id="@+id/bx2y1"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:text="" />

</LinearLayout>
<LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal" >
    <Button
        android:layout_weight="1"
        android:id="@+id/bx1y2"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:text="" />
    <Button
        android:layout_weight="1"
        android:id="@+id/bx2y2"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:text="" />

</LinearLayout>
</LinearLayout>
</RelativeLayout>

// MainActivity

import android.os.Bundle;
import android.app.Activity;
import android.view.View;
import android.graphics.Color;
import android.widget.Button;
import android.widget.RelativeLayout;

public class MainActivity extends Activity {

      DrawView drawView;

      Button bx1y1,bx2y1,bx1y2,bx2y2;
      RelativeLayout rl1;
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);

         bx1y1 = (Button) findViewById(R.id.bx1y1);
         bx2y1 = (Button) findViewById(R.id.bx2y1);
         bx1y2 = (Button) findViewById(R.id.bx1y2);
         bx2y2 = (Button) findViewById(R.id.bx2y2);
         rl1 =(RelativeLayout)findViewById(R.id.rl1);


         bx2y1.setOnClickListener(new View.OnClickListener() {  
                @Override
                public void onClick(View arg0) {
                    drawline(1);
                }
            });

         bx1y2.setOnClickListener(new View.OnClickListener() {  
                @Override
                public void onClick(View arg0) {
                    drawline(3);
                    drawline(6);
                }
            });

         bx2y2.setOnClickListener(new View.OnClickListener() {  
                @Override
                public void onClick(View arg0) {
                    drawline(2);
                    drawline(4);

                    drawline(5);
                }
            });
        }
        protected void drawline(int linenum) {
            switch (linenum) {
            case 1://x start
                drawView = new DrawView(MainActivity.this,bx1y1,bx2y1,18,18,18,18);
                  rl1.addView(drawView);
                break;
            case 2:
                drawView = new DrawView(MainActivity.this,bx1y2,bx2y2,18,54,18,54);
                  rl1.addView(drawView);
                break;
            case 3:
                drawView = new DrawView(MainActivity.this,bx1y1,bx1y2,18,18,18,54);
                  rl1.addView(drawView);
                break;
            case 4:
                drawView = new DrawView(MainActivity.this,bx2y1,bx2y2,18,18,18,54);
                rl1.addView(drawView);
                break;
            case 5:
                drawView = new DrawView(MainActivity.this,bx1y1,bx2y2,18,18,18,54);
                rl1.addView(drawView);
                break;
            case 6:
                drawView = new DrawView(MainActivity.this,bx2y1,bx1y2,18,18,18,54);
                rl1.addView(drawView);
                break;

            default:
                break;
            }

        }
}

// drawView函数

import android.annotation.SuppressLint;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.view.View;

public class DrawView extends View {
    Paint paint = new Paint();
    View startView;
    View endView;
    int sx,sy,ex,ey;

    public DrawView(Context context,View startView,View endView,int sx,int sy,int ex,int ey) {
        super(context);
        paint.setColor(Color.BLACK);        
        this.startView = startView;
        this.endView = endView;
        this.sx=sx;
        this.sy=sy;
        this.ex=ex;
        this.ey=ey;
    }

    @SuppressLint("NewApi")
    public void onDraw(Canvas canvas) {
            canvas.drawLine(startView.getX()+sx, startView.getY()+sy, endView.getX()+ex, endView.getY()+ey, paint);
    }

}

1 个答案:

答案 0 :(得分:1)

<View android:layout_width="match_parent"
  android:layout_height="2dp"
  android:background="@android:color/white" />  

这将创建一个2dp高的水平线。在两个按钮之间添加此项,并在RelativeLayout

中进行适当的定位

如果你想在两个按钮之间有一个更自定义的线条,另一个选择就是使用一个可绘制的形状。