diff --git a/src/html5-qrcode.ts b/src/html5-qrcode.ts index 108bdb7..f902e7c 100644 --- a/src/html5-qrcode.ts +++ b/src/html5-qrcode.ts @@ -1461,6 +1461,7 @@ export class Html5Qrcode { private createVideoElement(width: number): HTMLVideoElement { const videoElement = document.createElement("video"); videoElement.style.width = `${width}px`; + videoElement.style.display = "block"; videoElement.muted = true; videoElement.setAttribute("muted", "true"); (videoElement).playsInline = true; @@ -1562,6 +1563,7 @@ export class Html5Qrcode { /* width= */ largeSize, /* height= */ smallSize, /* top= */ -smallSize, + /* bottom= */ null, /* side= */ 0, /* isLeft= */ true); this.insertShaderBorders( @@ -1569,20 +1571,23 @@ export class Html5Qrcode { /* width= */ largeSize, /* height= */ smallSize, /* top= */ -smallSize, + /* bottom= */ null, /* side= */ 0, /* isLeft= */ false); this.insertShaderBorders( shadingElement, /* width= */ largeSize, /* height= */ smallSize, - /* top= */ qrboxSize.height + smallSize, + /* top= */ null, + /* bottom= */ -smallSize, /* side= */ 0, /* isLeft= */ true); this.insertShaderBorders( shadingElement, /* width= */ largeSize, /* height= */ smallSize, - /* top= */ qrboxSize.height + smallSize, + /* top= */ null, + /* bottom= */ -smallSize, /* side= */ 0, /* isLeft= */ false); this.insertShaderBorders( @@ -1590,13 +1595,15 @@ export class Html5Qrcode { /* width= */ smallSize, /* height= */ largeSize + smallSize, /* top= */ -smallSize, + /* bottom= */ null, /* side= */ -smallSize, /* isLeft= */ true); this.insertShaderBorders( shadingElement, /* width= */ smallSize, /* height= */ largeSize + smallSize, - /* top= */ qrboxSize.height + smallSize - largeSize, + /* top= */ null, + /* bottom= */ -smallSize, /* side= */ -smallSize, /* isLeft= */ true); this.insertShaderBorders( @@ -1604,13 +1611,15 @@ export class Html5Qrcode { /* width= */ smallSize, /* height= */ largeSize + smallSize, /* top= */ -smallSize, + /* bottom= */ null, /* side= */ -smallSize, /* isLeft= */ false); this.insertShaderBorders( shadingElement, /* width= */ smallSize, /* height= */ largeSize + smallSize, - /* top= */ qrboxSize.height + smallSize - largeSize, + /* top= */ null, + /* bottom= */ -smallSize, /* side= */ -smallSize, /* isLeft= */ false); this.hasBorderShaders = true; @@ -1622,7 +1631,8 @@ export class Html5Qrcode { shaderElem: HTMLDivElement, width: number, height: number, - top: number, + top: number|null, + bottom: number|null, side: number, isLeft: boolean) { const elem = document.createElement("div"); @@ -1630,7 +1640,12 @@ export class Html5Qrcode { elem.style.backgroundColor = Constants.BORDER_SHADER_DEFAULT_COLOR; elem.style.width = `${width}px`; elem.style.height = `${height}px`; - elem.style.top = `${top}px`; + if (top !== null) { + elem.style.top = `${top}px`; + } + if (bottom !== null) { + elem.style.bottom = `${bottom}px`; + } if (isLeft) { elem.style.left = `${side}px`; } else {