如何在android中绘制一个半圈

时间:2015-07-29 16:14:38

标签: android

我使用此代码在我的应用中绘制了一半:

  <?xml version="1.0" encoding="utf-8" ?>
<layer-list
    xmlns:android="http://schemas.android.com/apk/res/android"
    >
    <item
        android:left="35dp"
        android:top="40dp"
        android:bottom="40dp"
        android:right="0dp">
        <shape
            xmlns:android="http://schemas.android.com/apk/res/android"
            android:shape="oval" android:innerRadius="30dp" android:thickness="0dp">
            <solid android:color="@color/transparent"/>
            <stroke android:width="3dp" android:color="@color/White"/>

        </shape>
    </item>
</layer-list>

输出:

enter image description here

但我需要以下内容:

enter image description here

如何画这个?

5 个答案:

答案 0 :(得分:14)

我建议通过代码绘制它。

1-创建MyView类并放在代码下面。

public class MyView extends View {

    public MyView(Context context) {
        super(context);
        // TODO Auto-generated constructor stub
    }

    @Override
    protected void onDraw(Canvas canvas) {

        // TODO Auto-generated method stub
        super.onDraw(canvas);
        float width = (float) getWidth();
        float height = (float) getHeight();
        float radius;

        if (width > height) {
         radius = height / 4;
        } else {
         radius = width / 4;
        }

        Path path = new Path();
        path.addCircle(width / 2,
         height / 2, radius,
         Path.Direction.CW);

        Paint paint = new Paint();
        paint.setColor(Color.BLACK);
        paint.setStrokeWidth(5);
        paint.setStyle(Paint.Style.FILL);

        float center_x, center_y;
        final RectF oval = new RectF();
        paint.setStyle(Paint.Style.STROKE);

        center_x = width / 2;
        center_y = height / 2;

        oval.set(center_x - radius,
            center_y - radius,
            center_x + radius,
            center_y + radius);
        canvas.drawArc(oval, 90, 180, false, paint);
    }
}

2 - 在您的活动或片段中初始化此类: -

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(new MyView(this));
}

答案 1 :(得分:13)

您可以使用矩形形状.xml文件并仅在一侧编辑角落。

示例:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <size android:height="30dp"
        android:width="30dp"/>
    <solid android:color="@color/black"/>
    <corners android:topLeftRadius="15dp"
        android:bottomLeftRadius="15dp"/>
</shape>

答案 2 :(得分:12)

您可以使用<clip /> drawable来截断圆圈的一部分。

http://developer.android.com/guide/topics/resources/drawable-resource.html#Clip

答案 3 :(得分:0)

这是我在可绘制的xml文件中创建半圆的方式。

<size
    android:width="180dp"
    android:height="90dp"></size>

<corners
    android:topLeftRadius="200dp"
    android:topRightRadius="200dp"></corners>

答案 4 :(得分:0)

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <size
        android:width="180dp"
        android:height="90dp"></size>

    <corners
        android:topLeftRadius="200dp"
        android:topRightRadius="200dp"></corners>
    <stroke android:width="5px" android:color="@color/black" />
</shape>