Skip to content

Commit

Permalink
Fix intel#66 - reset orientation
Browse files Browse the repository at this point in the history
  • Loading branch information
kenchris committed Sep 21, 2018
1 parent 8599c84 commit 555c1e1
Show file tree
Hide file tree
Showing 5 changed files with 42 additions and 8 deletions.
2 changes: 1 addition & 1 deletion sensor-tester/build/bundled/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion sensor-tester/build/bundled/service-worker.js
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@
/* eslint-disable indent, no-unused-vars, no-multiple-empty-lines, max-nested-callbacks, space-before-function-paren, quotes, comma-spacing */
'use strict';

var precacheConfig = [["images/app-icon-128.png","5c67806f6bd216fe041c9fc4d9a7fc8a"],["images/app-icon-144.png","aea337293cc66ce854f5f20e54b5197f"],["images/app-icon-192.png","c9d515ce9875b4fcf765e4fb1c59d700"],["images/app-icon-48.png","7894f4722aa34a56a6edbb22318ec6d1"],["index.html","44395f5fdb2e133b257d8d11265e7985"],["manifest.json","c207e76d6dc3a3b0ce2e74c61ffe1256"]];
var precacheConfig = [["images/app-icon-128.png","5c67806f6bd216fe041c9fc4d9a7fc8a"],["images/app-icon-144.png","aea337293cc66ce854f5f20e54b5197f"],["images/app-icon-192.png","c9d515ce9875b4fcf765e4fb1c59d700"],["images/app-icon-48.png","7894f4722aa34a56a6edbb22318ec6d1"],["index.html","458bd8b85a3e25b40437c223346f5230"],["manifest.json","c207e76d6dc3a3b0ce2e74c61ffe1256"]];
var cacheName = 'sw-precache-v3--' + (self.registration ? self.registration.scope : '');


Expand Down
36 changes: 31 additions & 5 deletions sensor-tester/src/orientation-changer.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,35 +5,61 @@ import "@material/mwc-formfield/mwc-formfield.js";
import "@material/mwc-button/mwc-button.js";

export class OrientationChanger extends LitElement {
static get properties() {
return {
log: {type:String}
}
}

constructor() {
super();
const docEl = document.documentElement;
this._requestFullScreen = docEl.requestFullscreen || docEl.webkitRequestFullscreen
|| docEl.mozRequestFullScreen || docEl.msRequestFullscreen;
this._cancelFullScreen = document.exitFullscreen || document.webkitExitFullscreen
|| document.mozCancelFullScreen || document.msExitFullscreen;
this._orientation = screen.msOrientation || (screen.orientation || screen.mozOrientation || {});

this.isChangedByMe = false;
this.log = '';

screen.orientation.addEventListener('change', () => {
if (!this.isChangedByMe) {
this.shadowRoot.querySelector('#one').checked = true;
}
// The event listener is called after lock() promise resolves.
this.isChangedByMe = false;
});
}

async lock(orientation) {
this.log = '';
this.isChangedByMe = true;
this._requestFullScreen.call(document.documentElement);
try {
await this._orientation.lock(orientation);
await screen.orientation.lock(orientation);
// Chrome/Android bug: Accepts lock to portrait-secondary but doesn't
// rotate and sent 'change' event.
setTimeout(() => {
this.isChangedByMe = false;
}, 500);
} catch(err) {
console.log("screen.orientation.lock() is not available on this device.");
console.log("Cannot lock to the requested orientation.");
this.log = "Failed";
this._cancelFullScreen.call(document);
this.shadowRoot.querySelector('#one').checked = true;
this.isChangedByMe = false;
};
}

unlock() {
this._orientation.unlock();
screen.orientation.unlock();
this._cancelFullScreen.call(document);
this.shadowRoot.querySelector('#one').checked = true;
}

render() {
return html`
<div>If the device supports it, lock to desired orientation before running the tests.</div>
${this.log}
<mwc-formfield label="">
<mwc-radio id="one" name="o" @click="${() => this.lock('portrait-primary')}" checked></mwc-radio>
</mwc-formfield>
Expand Down
8 changes: 8 additions & 0 deletions sensor-tester/src/sensor-tester.js
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,14 @@ class SensorTester extends LitElement {

const parts = pathname.slice(1).split('/');
this.page = parts[parts.length - 1] || 'accelerometer';

if (screen.orientation) {
screen.orientation.unlock();
}
const exitFullscreen = document.exitFullscreen || document.webkitExitFullscreen
|| document.mozCancelFullScreen || document.msExitFullscreen;
exitFullscreen.call(document);

if (this.drawer && !this.drawer.persistent) {
this.drawer.close();
}
Expand Down
2 changes: 1 addition & 1 deletion sensor-tester/src/sensor-tests-page.js
Original file line number Diff line number Diff line change
Expand Up @@ -243,7 +243,7 @@ class SensorTestsPage extends LitElement {
<div class="${classMap({'hidden': this.isSupported})}">Sensor is not supported by the browser or the device.</div>
<div class="${classMap({'hidden': !this.isSupported})}">
<div class="${this.referenceFrame}">
<div class="${classMap({'hidden': this.referenceFrame === 'device' || !screen.orientation})}">
<orientation-changer></orientation-changer>
</div>
Expand Down

0 comments on commit 555c1e1

Please sign in to comment.