Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

avoid incomplete webp support in Edge 18 #7687

Merged
merged 5 commits into from
Dec 12, 2018
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
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 @@ -1539,6 +1540,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