egret mask 显示异常

发布于 2022-09-03 00:19:56 字数 1810 浏览 19 评论 0

我想画一个圆形头像, 外围有一圈白边, 像这样:
图片描述
(橙色背景是用来显示白圈的, 不属于头像部分)

我是这样写的: 建一个Avatar类,写一个common() 方法用来画这种头像:
先画一个大点的圆, 然后放上照片, 然后再画一个小一点的圆作为照片的mask;
然后就可以在别的地方调用了

common方法是这么写的:

        var circle = new egret.Sprite();
        // mask
        var circleMask = new egret.Shape();
        circle.graphics.beginFill(0xffffff);
        circle.graphics.drawCircle(this.centerX, this.centerY, this.diameter/2);
        circle.graphics.endFill();

        circleMask.graphics.beginFill(0x000000);
        var maskDiameter: number = this.diameter -12;
        circleMask.graphics.drawCircle(this.centerX, this.centerY, maskDiameter/2);
        circleMask.graphics.endFill();

        circle.addChild(this.photo);
        circle.addChild(circleMask);
        this.photo.mask = circleMask;
        this.addChild(circle);

然后我想在一个弹出框里画一个头像, 关键代码差不读是这样:

        var avatar = new Avatar("test_avatar_jppg", 260); //图片和直径
        avatar.common();    // 调用上面说的common()方法
        avatar.x = this.dialogX + this.dialogWidth/2 - avatar.width/2;
        avatar.y = this.dialogY + this.dialogHeight/2 + avatar.height/2;
        this.addChild(avatar);

理想效果应该是这个样子:
点击开始(当然以后会改成别的触发条件) 弹出一个对话框, 对话框上有个头像:
图片描述
图片描述

不幸的事情发生了, 我点开始的时候他先给我这么个图然后我再点一下开始的时候它才给我显示上面那个对话框的图:

图片描述

求大神帮我看看应该怎么搞

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文