在多个画布上默认禁用 imageSmoothingEnabled
我正在创建一个使用分层画布和精灵图像的基于浏览器的游戏,出于视觉和性能原因,我想默认禁用 imageSmoothingEnabled.据我了解,imageSmoothingEnabled 并非在所有浏览器中都可用,但有供应商前缀版本.我试图找到一种优雅的方法来默认在我的所有画布上禁用此属性(在尽可能多的浏览器中).到目前为止,这是我的方法:
I'm creating a browser-based game that uses layered canvases and sprite images, and for visual and performance reasons I would like to disable imageSmoothingEnabled by default. It's my understanding that imageSmoothingEnabled isn't available in all browsers, but there are vendor-prefixed versions. I am trying to find an elegant way to disable this attribute by default across all my canvases (in as many browsers as possible). So far, this is my method:
context1.imageSmoothingEnabled = false;
context1.mozImageSmoothingEnabled = false;
context1.oImageSmoothingEnabled = false;
context1.webkitImageSmoothingEnabled = false;
context2.imageSmoothingEnabled = false;
context2.mozImageSmoothingEnabled = false;
context2.oImageSmoothingEnabled = false;
context2.webkitImageSmoothingEnabled = false;
context3.imageSmoothingEnabled = false;
context3.mozImageSmoothingEnabled = false;
context3.oImageSmoothingEnabled = false;
context3.webkitImageSmoothingEnabled = false;
//etc...
还有更优雅的方法吗?在实际创建每个画布上下文之前,是否可以将上下文的 API 更改为默认值?
Is there a more elegant approach? Is it perhaps possible to change the context's API to default to false, before actually creating each canvas context?
推荐答案
是的,你有一个更简洁的方法:因为你总是会通过在画布上使用 getContext('2d')
来获取上下文,您可以注入 getContext
,以便它在返回上下文之前执行您喜欢的任何设置.
Yes, you have a cleaner approach : since you will always get a context by using getContext('2d')
on a canvas, you can inject getContext
, so that it does any setup of your like before returning the context.
以下代码成功地将所有上下文的平滑设置为 false:
The following piece of code successfully sets the smoothing to false for all your contexts :
(很明显,它应该在调用 getContext 之前运行).
(it should, quite obviously, be run before any call to getContext).
// save old getContext
var oldgetContext = HTMLCanvasElement.prototype.getContext ;
// get a context, set it to smoothed if it was a 2d context, and return it.
function getSmoothContext(contextType) {
var resCtx = oldgetContext.apply(this, arguments);
if (contextType == '2d') {
setToFalse(resCtx, 'imageSmoothingEnabled');
setToFalse(resCtx, 'mozImageSmoothingEnabled');
setToFalse(resCtx, 'oImageSmoothingEnabled');
setToFalse(resCtx, 'webkitImageSmoothingEnabled');
}
return resCtx ;
}
function setToFalse(obj, prop) { if ( obj[prop] !== undefined ) obj[prop] = false; }
// inject new smoothed getContext
HTMLCanvasElement.prototype.getContext = getSmoothContext ;
Rq 你可以在你的"getContext 中做任何事情.我使用它在上下文中复制画布的宽度、高度,以便在没有 DOM 访问的情况下将它们放在手边.
Rq that you can do anything in 'your' getContext. I use it to copy canvas's width, height on the context to have them at hand with no DOM access, among other things.
相关文章