在测试WebGL上下文后删除WebGL上下文

时间:2017-12-17 14:22:29

标签: html5-canvas webgl

出于好奇,我想看看使用以下代码的各种访问者支持WebGL的上下文:

var e = document.createElement('canvas');
var c = ['webgl','ms-webgl','experimental-webgl','moz-webgl']; 
for (var y = -1, len = c.length; ++y < len;)
{
 try {if (e.getContext(c[y])) {/*do-a-jig*/ break;}} catch(e) {}
}

不幸的是,这在Web开发人员控制台中报告了一个非常难以重现的错误:

  

WebGL警告:超过此主体的16个实时WebGL上下文,   失去最近最少使用的那个。

所以问题只是简单地说,在测试上下文后如何删除该上下文以避免产生此错误?

1 个答案:

答案 0 :(得分:0)

您可以尝试类似:(未经测试)

var e = document.createElement('canvas');
var c = ['webgl','ms-webgl','experimental-webgl','moz-webgl']; 

var found = '';
for (var y=0; y<c.length; y++)
{
    try {
        var ctx = e.getContext(c[y]);
        if (ctx) {
            found = c[y];
            ctx.getExtension('WEBGL_lose_context').loseContext();
            break;
        }

    } catch(e) { }
}