如何使用x,y,width和height属性绘制六边形?

时间:2018-12-27 17:18:54

标签: c# android xamarin path shapes

我需要使用x,y,width和height属性绘制六边形。

1 个答案:

答案 0 :(得分:0)

我根据您的描述编写了一个演示,这是有关该演示的屏幕截图。

enter image description here

这是此演示的代码。

activity_main.axml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <ImageView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/iv_ImageView"
        />
</RelativeLayout>

MainActivity.cs

[Activity(Label = "@string/app_name", Theme = "@style/AppTheme", MainLauncher = true)]
public class MainActivity : AppCompatActivity
{
    protected override void OnCreate(Bundle savedInstanceState)
    {
        base.OnCreate(savedInstanceState);
        // Set our view from the "main" layout resource
        SetContentView(Resource.Layout.activity_main);

        ImageView iv_ImageView = FindViewById<ImageView>(Resource.Id.iv_ImageView);
        Bitmap icon=BitmapFactory.DecodeResource(Resources,Resource.Drawable.Capture);
        new shape(icon, iv_ImageView);
    }
}

您可以在此getHexagonalCroppedBitmap方法中设置宽度,高度和XY(我默认设置width=150height =150centerX = width / 2; centerY = height / 2; 。您可以更改该设置)。 shape.cs

internal class shape
{
    private Bitmap bmp;
    private ImageView img;

    public shape(Bitmap bmp, ImageView img)
    {
        this.bmp = bmp;
        this.img = img;
        onDraw();
    }

    private void onDraw()
    {
        if(bmp.Width == 0 || bmp.Height == 0)
        {

            return;
        }

        int w = bmp.Width, h = bmp.Height;

        Bitmap roundBitmap = getHexagonalCroppedBitmap(bmp, h);
        img.SetImageBitmap(roundBitmap);
    }

    private Bitmap getHexagonalCroppedBitmap(Bitmap bitmap, int radius)
    {
        Bitmap finalBitmap;
        if (bitmap.Width != radius || bitmap.Height!= radius)
            finalBitmap = Bitmap.CreateScaledBitmap(bitmap, radius, radius,
                    false);
        else
            finalBitmap = bitmap;
        Bitmap output = Bitmap.CreateBitmap(finalBitmap.Width,
                finalBitmap.Height, Bitmap.Config.Argb8888);
        Canvas canvas = new Canvas(output);

        Paint paint = new Paint();
        Rect rect = new Rect(0, 0, finalBitmap.Width,
                finalBitmap.Height);

        //note:you could set width and height in here
        int width = 150;
        int height = 150;
        //note: you could set x and y in here, i set the  centerX = width / 2;centerY = height / 2; by default.

        float centerX = width / 2;
        float centerY = height / 2;

        float radiusValue = width / 2;
        double radian30 = 30 * Math.PI / 180;
        float a = (float)(radiusValue * Math.Sin(radian30));
        float b = (float)(radiusValue * Math.Cos(radian30));

        Path path = new Path();
        path.MoveTo(centerX, 0);

        path.LineTo(centerX + b, centerY - a);
        path.LineTo(centerX + b, centerY + a);
        path.LineTo(centerX, height);
        path.LineTo(centerX - b, centerY + a);
        path.LineTo(centerX - b, centerY - a);

        path.Close();
        canvas.DrawARGB(0, 0, 0, 0);
        paint.Color=(Color.ParseColor("#BAB399"));
        canvas.DrawPath(path, paint);
        paint.SetXfermode(new PorterDuffXfermode(PorterDuff.Mode.SrcIn));
        canvas.DrawBitmap(finalBitmap, rect, rect, paint);

        return output;
    }
}