diff --git a/debug/fog.html b/debug/fog.html index 66fb010eb73..cb936577b35 100644 --- a/debug/fog.html +++ b/debug/fog.html @@ -33,8 +33,8 @@ this.enableSky = true; this.terrainExaggeration = 1.5; this.style = 'satellite-streets-v11'; - this.fogRangeStart = 1000; - this.fogRangeEnd = 10000; + this.fogRangeStart = 1.5; + this.fogRangeEnd = 2.0; this.fogColor = [255, 255, 255]; this.fogSkyBlend = 0.1; this.showTileBoundaries = false; @@ -111,14 +111,14 @@ }); }); - var fogRangeStart = fog.add(guiParams, 'fogRangeStart', 0.0, 15000.0); + var fogRangeStart = fog.add(guiParams, 'fogRangeStart', 0.0, 15.0); fogRangeStart.onFinishChange((value) => { map.setFog({ "range": [value, guiParams.fogRangeEnd], }); }); - var fogRangeEnd = fog.add(guiParams, 'fogRangeEnd', 0.0, 15000.0); + var fogRangeEnd = fog.add(guiParams, 'fogRangeEnd', 0.0, 15.0); fogRangeEnd.onFinishChange((value) => { map.setFog({ "range": [guiParams.fogRangeStart, value], diff --git a/src/geo/transform.js b/src/geo/transform.js index b38685d0052..f358a7bc5d7 100644 --- a/src/geo/transform.js +++ b/src/geo/transform.js @@ -1497,8 +1497,9 @@ class Transform { mat4.scale(m, m, metersToPixel); this.mercatorFogMatrix = m; - // matrix for conversion from tile coordinates to relative camera position in pixel coordinates - this.cameraMatrix = this._camera.getWorldToCameraPosition(cameraWorldSize, cameraPixelsPerMeter); + // matrix for conversion from tile coordinates to relative camera position in units of fractions of the map height + const windowScaleFactor = 1.0 / this.height; + this.cameraMatrix = this._camera.getWorldToCameraPosition(cameraWorldSize, cameraPixelsPerMeter, windowScaleFactor); // inverse matrix for conversion from screen coordinates to location m = mat4.invert(new Float64Array(16), this.pixelMatrix); diff --git a/src/style-spec/reference/v8.json b/src/style-spec/reference/v8.json index 3f48b598b74..dbeec1f9187 100644 --- a/src/style-spec/reference/v8.json +++ b/src/style-spec/reference/v8.json @@ -3681,9 +3681,11 @@ "range": { "type": "array", "default": [ - 3000, - 8000 + 5, + 10 ], + "minimum": 0, + "maximum": 20, "length": 2, "value": "number", "property-type": "data-constant", @@ -3696,8 +3698,8 @@ }, "doc": "", "example": [ - 3000, - 8000 + 5, + 10 ], "sdk-support": { "basic functionality": { diff --git a/src/style-spec/validate/validate_fog.js b/src/style-spec/validate/validate_fog.js index 52227fa493f..ba71a163ccf 100644 --- a/src/style-spec/validate/validate_fog.js +++ b/src/style-spec/validate/validate_fog.js @@ -18,12 +18,8 @@ export default function validateFog(options) { return errors; } - if (fog.range && fog.range[0] > fog.range[1]) { - errors = errors.concat([new ValidationError('fog', fog, 'fog.range[0] can\'t be greater than fog.range[1]')]); - } - - if (fog.range && (fog.range[0] < 0 || fog.range[1] < 0)) { - errors = errors.concat([new ValidationError('fog', fog, 'fog.range can\'t be negative')]); + if (fog.range && fog.range[0] >= fog.range[1]) { + errors = errors.concat([new ValidationError('fog', fog, 'fog.range[0] can\'t be greater than or equal to fog.range[1]')]); } for (const key in fog) { diff --git a/src/ui/free_camera.js b/src/ui/free_camera.js index dcc006e47e0..e249de7b896 100644 --- a/src/ui/free_camera.js +++ b/src/ui/free_camera.js @@ -247,15 +247,16 @@ class FreeCamera { return cameraToWorld; } - getWorldToCameraPosition(worldSize: number, pixelsPerMeter: number): Float64Array { + getWorldToCameraPosition(worldSize: number, pixelsPerMeter: number, uniformScale: number): Float64Array { const invPosition = this.position; vec3.scale(invPosition, invPosition, -worldSize); const matrix = new Float64Array(16); - mat4.fromTranslation(matrix, invPosition); + mat4.fromScaling(matrix, [uniformScale, uniformScale, uniformScale]); + mat4.translate(matrix, matrix, invPosition); // Adjust scale on z (3rd column 3rd row) - matrix[10] = pixelsPerMeter; + matrix[10] *= pixelsPerMeter; return matrix; } diff --git a/test/unit/style-spec/fixture/fog-invalid-input.input.json b/test/unit/style-spec/fixture/fog-invalid-input.input.json index 87661ae1fd2..10b840da5e1 100644 --- a/test/unit/style-spec/fixture/fog-invalid-input.input.json +++ b/test/unit/style-spec/fixture/fog-invalid-input.input.json @@ -8,7 +8,7 @@ }, "layers": [], "fog": { - "range": [-2000, -1000], + "range": [-2, -1], "sky-blend": -4 } -} \ No newline at end of file +} diff --git a/test/unit/style-spec/fixture/fog-invalid-input.output-api-supported.json b/test/unit/style-spec/fixture/fog-invalid-input.output-api-supported.json index 65e89b40264..328a8b4042b 100644 --- a/test/unit/style-spec/fixture/fog-invalid-input.output-api-supported.json +++ b/test/unit/style-spec/fixture/fog-invalid-input.output-api-supported.json @@ -1,10 +1,14 @@ [ { - "line": 10, - "message": "fog: fog.range can't be negative" + "line": 11, + "message": "range[0]: -2 is less than the minimum value 0" + }, + { + "line": 11, + "message": "range[1]: -1 is less than the minimum value 0" }, { "line": 12, "message": "sky-blend: -4 is less than the minimum value 0" } -] \ No newline at end of file +] diff --git a/test/unit/style-spec/fixture/fog-invalid-input.output.json b/test/unit/style-spec/fixture/fog-invalid-input.output.json index 65e89b40264..328a8b4042b 100644 --- a/test/unit/style-spec/fixture/fog-invalid-input.output.json +++ b/test/unit/style-spec/fixture/fog-invalid-input.output.json @@ -1,10 +1,14 @@ [ { - "line": 10, - "message": "fog: fog.range can't be negative" + "line": 11, + "message": "range[0]: -2 is less than the minimum value 0" + }, + { + "line": 11, + "message": "range[1]: -1 is less than the minimum value 0" }, { "line": 12, "message": "sky-blend: -4 is less than the minimum value 0" } -] \ No newline at end of file +] diff --git a/test/unit/style-spec/fixture/fog-invalid-range.input.json b/test/unit/style-spec/fixture/fog-invalid-range.input.json index cea73c34fd8..b1d2620a33e 100644 --- a/test/unit/style-spec/fixture/fog-invalid-range.input.json +++ b/test/unit/style-spec/fixture/fog-invalid-range.input.json @@ -8,6 +8,6 @@ }, "layers": [], "fog": { - "range": [2000, 1000] + "range": [2, 1] } -} \ No newline at end of file +} diff --git a/test/unit/style-spec/fixture/fog-invalid-range.output-api-supported.json b/test/unit/style-spec/fixture/fog-invalid-range.output-api-supported.json index 406a510f641..22b8794f01f 100644 --- a/test/unit/style-spec/fixture/fog-invalid-range.output-api-supported.json +++ b/test/unit/style-spec/fixture/fog-invalid-range.output-api-supported.json @@ -1,6 +1,6 @@ [ { "line": 10, - "message": "fog: fog.range[0] can't be greater than fog.range[1]" + "message": "fog: fog.range[0] can't be greater than or equal to fog.range[1]" } -] \ No newline at end of file +] diff --git a/test/unit/style-spec/fixture/fog-invalid-range.output.json b/test/unit/style-spec/fixture/fog-invalid-range.output.json index 406a510f641..22b8794f01f 100644 --- a/test/unit/style-spec/fixture/fog-invalid-range.output.json +++ b/test/unit/style-spec/fixture/fog-invalid-range.output.json @@ -1,6 +1,6 @@ [ { "line": 10, - "message": "fog: fog.range[0] can't be greater than fog.range[1]" + "message": "fog: fog.range[0] can't be greater than or equal to fog.range[1]" } -] \ No newline at end of file +] diff --git a/test/unit/style/style.test.js b/test/unit/style/style.test.js index 8585c6a7432..0069473c364 100644 --- a/test/unit/style/style.test.js +++ b/test/unit/style/style.test.js @@ -2360,7 +2360,7 @@ test('Style#setFog', (t) => { const style = new Style(new StubMap()); style.loadJSON({ "version": 8, - "fog": {"range": [1000, 2000], "color": "white", "sky-blend": 0.05}, + "fog": {"range": [1, 2], "color": "white", "sky-blend": 0.05}, "sources": {}, "layers": [] }); @@ -2382,15 +2382,15 @@ test('Style#getFog', (t) => { const style = new Style(new StubMap()); style.loadJSON({ "version": 8, - "fog": {"range": [1000, 2000], "color": "white", "sky-blend": 0.05}, + "fog": {"range": [1, 2], "color": "white", "sky-blend": 0.05}, "sources": {}, "layers": [] }); style.on('style.load', () => { - style.setFog({"range": [0, 1000], "color": "white", "sky-blend": 0.0}); + style.setFog({"range": [0, 1], "color": "white", "sky-blend": 0.0}); t.ok(style.getFog()); - t.deepEqual(style.getFog(), {"range": [0, 1000], "color": "white", "sky-blend": 0.0}); + t.deepEqual(style.getFog(), {"range": [0, 1], "color": "white", "sky-blend": 0.0}); t.end(); }); });