반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- v-html
- scss
- storybook
- jsx
- 자료구조
- 쉬운설명
- express
- Wecode
- event
- input
- ES6
- Vue.js
- vuex
- HOC
- 자바스크립트
- App.vue
- mapGetters
- Vue transition
- TypeScript
- Vue
- react
- sass
- MySQL
- JavaScript
- webpack
- nodejs
- CSS
- State
- 리액트
- 댓글달기
Archives
- Today
- Total
익명의 개발노트
[Wecode 62일차] fullscreen 이슈 본문
반응형
1. fullscreen 시 esc키 눌렀을 경우 무한루프 + 이벤트 적용안되는 현상
const supportsOrientationChange = "onorientationchange" in window,
orientationEvent = supportsOrientationChange ? "orientationchange" : "resize";
console.log("orientationEvent",orientationEvent)
window.addEventListener(orientationEvent, () => this.toggleFullScreenBtn(), false);
document.addEventListener("fullscreenchange",(e) => this.onFullScreenChange(e), false);
document.addEventListener("mozfullscreenchange", (e) => this.onFullScreenChange(e), false);
document.addEventListener("webkitfullscreenchange", (e) => this.onFullScreenChange(e), false);
document.addEventListener("msfullscreenchange", (e) => this.onFullScreenChange(e), false);
this.toggleFullScreenBtn();
onFullScreenChange()
{
setTimeout(() => {
let vx = this.state.rangeValue;
this.setState({rangeValue: [vx[0] + 1]}); //Change to some value to refresh
this.setState({rangeValue: vx}); //And change back again
}, 100);
}
toggleFullScreenBtn() {
const browserName = new uaparser(navigator.userAgent).getBrowser().name;
console.log("toggleFullscreen",browserName)
const isNormalBrowser = (browserName.localeCompare("Chrome") === 0
|| browserName.localeCompare("Chrome Headless") === 0
|| browserName.localeCompare("Chrome WebView") === 0
|| browserName.localeCompare("Chromium") === 0
|| browserName.localeCompare("Firefox") === 0
|| browserName.localeCompare("Opera Coast") === 0
|| browserName.localeCompare("Opera Mini") === 0
|| browserName.localeCompare("Opera Mobi") === 0
|| browserName.localeCompare("Opera") === 0
|| browserName.localeCompare("Opera Tablet") === 0);
let ua = navigator.userAgent.toLowerCase();
let isAndroid = ua.indexOf("android") > -1; //&& ua.indexOf("mobile");
let isIOS = /Mac|iPad|iPhone|iPod/.test(navigator.userAgent) && !window.MSStream;
if (!isIOS) {
if (isAndroid && isNormalBrowser) {
this.setState({
showFullScreenBtn: true
});
} else if (isAndroid) {
this.setState({
showFullScreenBtn: window.screen.orientation.type.toString() === "landscape-primary"
|| window.screen.orientation.type.toString() === "landscape-secondary"
});
} else {
this.setState({showFullScreenBtn: true}); // not Android + not IOS = desktop device
}
if (((window.screen.orientation.type === "portrait-primary") //set off full screen in bad browser because having issue with scrolling in fullScreen mode
|| (window.screen.orientation.type === "portrait-secondary")) && !isNormalBrowser) {
if (this.state.isFull)
this.setState({isFull: false})
}
} else {
this.setState({showFullScreenBtn: false}); // ios not supporting full Screen
}
}
위 코드는 러시아 형이 만든 코드... esc 만누르면 무한루프 발생..
나도 따로 만들어야했기에 컴포넌트로 뺐다.
모든 fullscreen API/ stack overflow esc 키이벤트 안먹히는 이슈를 다 뒤져본 것 같다.
오죽했으면, 브라우져에서 먹히는게 window.innerHeight 일뿐... key이벤트도 안먹혔는데..
라이프싸이클도 인식못했는데.. 결론은 침착하게 다시.
import React, {Component} from "react";
import "./FullScreenButton.css";
export class FullScreenButton extends Component{
state = {
isFull : false,
}
componentDidMount = ()=>{
window.addEventListener('fullscreenchange', (e) => {
this.setState({ isFull: document.fullscreen })
})
}
handleFullScreen = (e) => {
const {isFull} = this.state;
this.setState({
isFull : !isFull
})
if(!isFull){
this.openFullscreen();
}else{
this.setState({isFull : false})
this.closeFullScreen();
}
}
openFullscreen = () => {
const element = document.documentElement;
if(element.requestFullscreen){
element.requestFullscreen();
}else if(element.mozRequestFullScreen){
element.mozRequestFullScreen();
}else if(element.webkitRequestFullscreen){
element.webkitRequestFullScreen();
}else if(element.msRequestFullscreen){
element.msRequestFullScreen();
}
}
closeFullScreen = () => {
if(document.exitFullscreen){
document.exitFullscreen();
}else if(document.mozCancleFullScreen){
document.mozCancleFullScreen();
}else if(document.webkitExitFullscreen){
document.webkitExitFullscreen();
}else if(document.msExitFullscreen){
document.msExitFullscreen();
}
}
render(){
const {isFull} = this.state;
return(
<div className={this.props.className}>
<button className={ !isFull ? "full-screen-btn" : "not-full-screen-btn"}
onClick={this.handleFullScreen}></button>
</div>
)
}
}
해결. 라이프사이클에 fullscreenchange 이벤트 찍히는지 체크하고.. 진행...
반응형
'코딩일기 > TIL' 카테고리의 다른 글
[데이터베이스] 삽입, 삭제하기. (0) | 2019.08.04 |
---|---|
[Wecode 63일차] fieldset , legend Tag, key pad 리팩토링 (0) | 2019.08.02 |
[Wecode 61일차] css 우선순위, line style function call, react-range (0) | 2019.07.31 |
[Wecode 55일차] 카카오 로그인, state (0) | 2019.07.26 |
[Wecode 54일차] mac<-> ubuntu 파일 대문자 인식못하는 현상 (0) | 2019.07.25 |
Comments