Skip to content

Commit

Permalink
avoid incomplete webp support in Edge 18 (#7687)
Browse files Browse the repository at this point in the history
  • Loading branch information
ansis authored Dec 12, 2018
1 parent 64ebdda commit 9cf6a0c
Show file tree
Hide file tree
Showing 6 changed files with 72 additions and 21 deletions.
3 changes: 3 additions & 0 deletions src/ui/map.js
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import { RGBAImage } from '../util/image';
import { Event, ErrorEvent } from '../util/evented';
import { MapMouseEvent } from './events';
import TaskQueue from '../util/task_queue';
import webpSupported from '../util/webp_supported';

import type {PointLike} from '@mapbox/point-geometry';
import type {LngLatLike} from '../geo/lng_lat';
Expand Down Expand Up @@ -1540,6 +1541,8 @@ class Map extends Camera {
}

this.painter = new Painter(gl, this.transform);

webpSupported.testSupport(gl);
}

_contextLost(event: *) {
Expand Down
11 changes: 1 addition & 10 deletions src/util/browser.js
Original file line number Diff line number Diff line change
Expand Up @@ -51,16 +51,7 @@ const exported = {
},

hardwareConcurrency: window.navigator.hardwareConcurrency || 4,
get devicePixelRatio() { return window.devicePixelRatio; },
supportsWebp: false
get devicePixelRatio() { return window.devicePixelRatio; }
};

export default exported;

if (window.document) {
const webpImgTest = window.document.createElement('img');
webpImgTest.onload = function() {
exported.supportsWebp = true;
};
webpImgTest.src = '';
}
3 changes: 2 additions & 1 deletion src/util/mapbox.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
import config from './config';

import browser from './browser';
import webpSupported from './webp_supported';
import window from './window';
import { version } from '../../package.json';
import { uuid, validateUuid, storageAvailable, warnOnce, extend } from './util';
Expand Down Expand Up @@ -101,7 +102,7 @@ export const normalizeTileURL = function(tileURL: string, sourceURL?: ?string, t
// is appended to the tile URL. If `tileSize: 512` is specified for
// a Mapbox raster source force the @2x suffix even if a non hidpi device.
const suffix = browser.devicePixelRatio >= 2 || tileSize === 512 ? '@2x' : '';
const extension = browser.supportsWebp ? '.webp' : '$1';
const extension = webpSupported.supported ? '.webp' : '$1';
urlObject.path = urlObject.path.replace(imageExtensionRe, `${suffix}${extension}`);
urlObject.path = `/v4${urlObject.path}`;

Expand Down
61 changes: 61 additions & 0 deletions src/util/webp_supported.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
// @flow

import window from './window';

const exported = {
supported: false,
testSupport
};

export default exported;

let glForTesting;
let webpCheckComplete = false;
let webpImgTest;

if (window.document) {
webpImgTest = window.document.createElement('img');
webpImgTest.onload = function() {
if (glForTesting) testWebpTextureUpload(glForTesting);
glForTesting = null;
};
webpImgTest.onerror = function() {
webpCheckComplete = true;
glForTesting = null;
};
webpImgTest.src = '';
}

function testSupport(gl: WebGLRenderingContext) {
if (webpCheckComplete || !webpImgTest) return;

if (!webpImgTest.complete) {
glForTesting = gl;
return;
}

testWebpTextureUpload(gl);
}

function testWebpTextureUpload(gl: WebGLRenderingContext) {
// Edge 18 supports WebP but not uploading a WebP image to a gl texture
// Test support for this before allowing WebP images.
// https://github.com/mapbox/mapbox-gl-js/issues/7671
const texture = gl.createTexture();
gl.bindTexture(gl.TEXTURE_2D, texture);

try {
gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, webpImgTest);

// The error does not get triggered in Edge if the context is lost
if (gl.isContextLost()) return;

exported.supported = true;
} catch (e) {
// Catch "Unspecified Error." in Edge 18.
}

gl.deleteTexture(texture);

webpCheckComplete = true;
}
5 changes: 0 additions & 5 deletions test/unit/util/browser.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,10 +33,5 @@ test('browser', (t) => {
t.end();
});

t.test('supportsWebp', (t) => {
t.equal(typeof browser.supportsWebp, 'boolean');
t.end();
});

t.end();
});
10 changes: 5 additions & 5 deletions test/unit/util/mapbox.test.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { test } from 'mapbox-gl-js-test';
import * as mapbox from '../../../src/util/mapbox';
import config from '../../../src/util/config';
import browser from '../../../src/util/browser';
import webpSupported from '../../../src/util/webp_supported';
import window from '../../../src/util/window';
import { uuid } from '../../../src/util/util';
import { version } from '../../../package.json';
Expand Down Expand Up @@ -287,7 +287,7 @@ test("mapbox", (t) => {
});

t.test('.normalizeTileURL', (t) => {
browser.supportsWebp = false;
webpSupported.supported = false;

t.test('does nothing on 1x devices', (t) => {
config.API_URL = 'http://path.png';
Expand Down Expand Up @@ -321,14 +321,14 @@ test("mapbox", (t) => {
});

t.test('replaces img extension with webp on supporting devices', (t) => {
browser.supportsWebp = true;
webpSupported.supported = true;
config.API_URL = 'http://path.png';
config.REQUIRE_ACCESS_TOKEN = false;
t.equal(mapbox.normalizeTileURL('http://path.png/tile.png', mapboxSource), 'http://path.png/v4/tile.webp');
t.equal(mapbox.normalizeTileURL('http://path.png/tile.png32', mapboxSource), 'http://path.png/v4/tile.webp');
t.equal(mapbox.normalizeTileURL('http://path.png/tile.jpg70', mapboxSource), 'http://path.png/v4/tile.webp');
t.equal(mapbox.normalizeTileURL('http://path.png/tile.png?access_token=foo', mapboxSource), 'http://path.png/v4/tile.webp?access_token=foo');
browser.supportsWebp = false;
webpSupported.supported = false;
t.end();
});

Expand Down Expand Up @@ -372,7 +372,7 @@ test("mapbox", (t) => {
t.end();
});

browser.supportsWebp = true;
webpSupported.supported = true;
t.end();
});

Expand Down

0 comments on commit 9cf6a0c

Please sign in to comment.