微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在临时画布中编辑图像,然后在主画布中重绘

如何解决在临时画布中编辑图像,然后在主画布中重绘

我正在画布上制作一个基于图块的游戏。我的精灵表由旧的 IBM 字体组成,我希望能够为每个像素的字体和背景着色,但似乎无法找到解决方案。有人告诉我在另一个画布上制作我的图像,即:设置背景和前景,然后将其重绘到当前画布,但我还没有想出如何做到这一点。

在我的代码中绘制一个字符到我使用的屏幕

this.font.drawChar(spriteGroup[z].grid[i][j],drawPosX,drawPosY )

我的 Font 类看起来像这样

class Font{
    constructor(src,tilesizeX,tilesizeY){
        this.fontimage = new Image();
        this.imageBuffer = new Image();
        this.fontimage.src = src;
    }

    drawChar(charCode,posX,posY,color){
        var scopeX = charmap[1][charmap[0].indexOf(charCode)][1] * 8;
        var scopeY = charmap[1][charmap[0].indexOf(charCode)][0] * 16
        game.ctx.globalCompositeOperation = "source-over";
        game.ctx.drawImage(this.fontimage,scopeX,scopeY,7,15,16,32);


    }
}

每个精灵都包含一个名为 colorMap 的二维数组,其中包含我将用来为每个图块引用颜色的代码,但我似乎无法在不引入巨大错误的情况下在画布上实现颜色更改。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?