首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Android自定义视图路径圆部分

Android自定义视图路径圆部分
EN

Stack Overflow用户
提问于 2021-04-04 03:41:19
回答 2查看 43关注 0票数 0

我一直在尝试创建自定义视图like this

我的代码

代码语言:javascript
复制
    Paint paint = new Paint();
    paint.setColor(Color.WHITE);
    paint.setStrokeWidth(6);
    float radius = getFloat(20);
    CornerPathEffect corEffect = new CornerPathEffect(radius);
    paint.setPathEffect(corEffect);
    Path path = new Path();
    path.reset();
    float top = getFloat(5);
    path.moveTo(0, top);
    float d = 80;
    path.lineTo((getWidth() - getFloat(d)) / 2, top);
    RectF oval = new RectF((getWidth() - getFloat(d)) / 2, top, (getWidth() + getFloat(d)) / 2, getFloat(d/2));
    path.arcTo(oval, 90, 360, false);

    path.lineTo((getWidth() + getFloat(d)) / 2, top);
    path.lineTo(getWidth(), top);
    path.lineTo(getWidth(), getHeight());
    path.lineTo(0, getHeight());
    path.close();

    paint.setShadowLayer(12, 0, 0, Color.argb(255, 200, 200, 200));
    setLayerType(LAYER_TYPE_SOFTWARE, paint);
    canvas.drawPath(path, paint);

and my result

如何让坑更圆like this

EN

回答 2

Stack Overflow用户

发布于 2021-04-04 04:28:46

您可以使用来实现您想要的功能。或者以对称方式使用Path.ovalTo()两次。

代码语言:javascript
复制
Path.cubicTo(float x1, float y1, float x2, float y2, float x3, float y3)
票数 0
EN

Stack Overflow用户

发布于 2021-04-04 23:23:03

Thx Faisal,我试试ovalTo

代码语言:javascript
复制
    Paint paint = new Paint();
    paint.setColor(Color.WHITE);
    paint.setStrokeWidth(6);
    float radius = getFloat(0);
    CornerPathEffect corEffect = new CornerPathEffect(radius);
    paint.setPathEffect(corEffect);
    Path path = new Path();
    path.reset();
    float top = getFloat(5);
    float round = getFloat(20);
    path.moveTo(0, getHeight());
    path.lineTo(0, round);
    path.cubicTo(0, top + round,
            0, top,
            round, top);

    float d = 80;
    path.lineTo(((getWidth() - getFloat(d)) / 2) - round, top);

    path.cubicTo(((getWidth() - getFloat(d)) / 2) - round, top,
            (getWidth() - getFloat(d)) / 2, top,
            (getWidth() - getFloat(d)) / 2, top + round);

    path.cubicTo((getWidth() - getFloat(d)) / 2, top,
            (getWidth() - getFloat(d)) / 2, getFloat(d/2),
            getWidth() / 2, getFloat(d/2));

    //-------------------

    path.cubicTo(getWidth() / 2, getFloat(d/2),
            (getWidth() + getFloat(d)) / 2, getFloat(d/2),
            (getWidth() + getFloat(d)) / 2, top);

    path.cubicTo((getWidth() + getFloat(d)) / 2, top + round,
            (getWidth() + getFloat(d)) / 2, top,
            ((getWidth() + getFloat(d)) / 2) + round, top);

    path.lineTo(((getWidth() + getFloat(d)) / 2) + round, top);
    path.lineTo(getWidth() - round, top);
    path.cubicTo(getWidth() - round, top,
            getWidth(), top,
            getWidth(), top + round);

    path.lineTo(getWidth(), getHeight());
    path.lineTo(0, getHeight());
    path.close();

    paint.setShadowLayer(12, 0, 0, Color.argb(255, 200, 200, 200));
    setLayerType(LAYER_TYPE_SOFTWARE, paint);
    canvas.drawPath(path, paint);

但我看到了artefacts

我不明白错误在哪里

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66935245

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档