Losowy Obrazek

Porn Animation VR

var mobileDevice = /iPhone|iPad|iPod|Android/i.test(navigator.userAgent); config = { fallbackImage : '', /* Time taken by animation to fade from 100% to 0% opacity at the start and the end of a clip Default: 400, value in millisecond (1000 = 1 second) */ fade:1000, /* Set the scale of animation and fallback. A scale of 0.5 divide the size by 2, A scale of 2 double the size Default: 1. You must set a scale value between 0.3 and 2 */ scale:1, /* Set the path to the videos folder. Can be relative (to your domain url) or can be absolute Default: '/'. Please never use istripper links, you must host videos by yourself. */ path:'/new_poppings/', /* This is your affiliation link. Make sure to add at least ?s=YOUR_ID to get the referal. Default: 'https://www.istripper.com' */ outlink:'https://www.istripper.com/?', /* If true then it will display a little cross allowing the user to close the popping model. WARNING: Setting this to false can lead to a ban of your site by Google Ad Policy. Default: true */ close:{}, /* If true, this will display a nice speech bubble with 'GET ME NOW' (customizable below) every 6 seconds on the girl Default: false */ bubble:false, /* ! Only if bubble is set to true This customize the speech bubble text. Note that you should keep this sentence around 12 characters long. Default: 'GET ME NOW !' */ bubbleText:'GET ME NOW !', /* If set to 'left', this will disable animations requiring to be at the right of the screen This will force other animations to be placed at the left of the screen. Default: 'auto'. Values can be 'left' or 'auto' */ position:'auto', /* Set the fallback position on the screen. Default: 'center'. Values can be 'left','right' or 'center' */ fallbackPosition:'right', /* ! Only if position is set to 'left' or fallbackPosition is not 'center' This set the offset between the left of the screen and the animation in pixel This also set the right or left offset for the fallback if fallbackPosition is set Default: 0 . Value is in pixel */ offset:0, /* Force the height of the fallback image in pixels Default: 223, Value must be between 100 and 223 */ fallbackSize:223, /* If true, then instead displaying fallback image, it will exit the popping model. Default: false */ disableFallback:false, /* Same as above, but only if the user is on mobile Default: false */ disableFallbackMobile:false, /* Time in second of deactivation after clicking the close button */ disableTimeClose:0, /* Time in second of deactivation after clicking on the popping */ disableTimeClick:0, } let popping_function = function () { var iterator=-1; var video; var ctx; var randomAnims=[]; function init () { if(typeof(loadTool) !== "undefined" ) { const timeClose = localStorage.getItem("disabledTimeClose"); const timeClick = localStorage.getItem("disabledTimeClick"); if( (timeClose != null && ( (new Date().getTime() / 1000) - (parseInt(timeClose) + (loadTool.disableTimeClose != undefined ? loadTool.disableTimeClose : config.disableTimeClose)) <= 0)) || (timeClick != null && ( (new Date().getTime() / 1000) - (parseInt(timeClick) + (loadTool.disableTimeClick != undefined ? loadTool.disableTimeClick : config.disableTimeClick)) <= 0)) ) { } else { let style = document.createElement('style'); style.type= 'text/css'; style.innerHTML += '@keyframes fadeIn { 0% { opacity: 0; }100% { opacity: 1; }}' style.innerHTML += '@keyframes fadeout { 0% { opacity: 1; }100% { opacity: 0; }}' style.innerHTML += '@keyframes TotemToolbounce { 0% { margin-top:0; } 25% { margin-top:-10px } 50% { margin-top:0 } 75% { margin-top:10px } 100% { margin-top:0 }}' style.innerHTML += '@keyframes TotemToolFade { 0% { opacity:0; -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=0)" } 77% { opacity:0; -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=0) } 80% { opacity:1; -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=100)" } 97% { opacity:1; -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=100)" } 100% { opacity:0; ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=0)" }}' document.getElementsByTagName('body')[0].append(style); video = document.createElement('video'); video.autoplay = "autoplay"; video.muted="muted"; video.preload="none"; video.crossOrigin="anonymous"; video.style.maxWidth="100%"; video.playsInline="playsinline"; video.addEventListener('ended', play, false); let div = document.createElement("div"); div.id = "basePopping"; div.append(video); document.getElementsByTagName('body')[0].append(div); video.addEventListener('mousemove',function(event) { if( alpha(event,this)===0 ) { this.style.cursor = "initial"; } else { this.style.cursor = "pointer"; } }) video.addEventListener('click', function handleMouseDown (event) { if( alpha(event,this)===0 ) { this.style.pointerEvents = "none"; this.parentNode.style.pointerEvents = "none"; setTimeout(function(){ video.style.pointerEvents = "auto"; video.parentNode.style.pointerEvents = "auto"; },1500) } else { let url = (loadTool.outlink ? loadTool.outlink : config.outlink); if(url.indexOf('%C%') > 1) { url = url.replace('%C%',loadTool.anims[iterator]['card']) } if(url.indexOf('%M%') > 1) { url = url.replace('%M%',"m"+loadTool.anims[iterator]['model']) } localStorage.setItem("disabledTimeClick", new Date().getTime() / 1000); //console.log( (loadTool.disableTimeClick != undefined ? loadTool.disableTimeClick : config.disableTimeClick) ) if ((loadTool.disableTimeClick != undefined ? loadTool.disableTimeClick : config.disableTimeClick) != 0) { document.getElementById("basePopping").remove(); } window.open(url); } }); //Close button if((loadTool.close != undefined && loadTool.close != false) || config.close != false) { if ( loadTool.close == undefined ) { loadTool.close = {}} let cl; if ( document.getElementById('closebtn') == null) { cl = document.createElement('div'); cl.innerHTML = 'X'; cl.id="closebtn"; cl.style.cssText = "position:absolute;bottom:0;font: small-caps "+ (loadTool.close.fontSize? loadTool.close.fontSize : 17) +"px / 17px Arial;box-shadow: rgba(0, 0, 0, 0.1) 0px 0px 5px inset;width: 15px;height: 15px;z-index: 10002;margin: 0px;border-radius: 3px;text-align: center;display: flex;justify-content: center;align-items: center;"; cl.style.color="white"; cl.style.background = (loadTool.close.color ? loadTool.close.color : "rgba(0, 0, 0, 0.5)") cl.style.width = (loadTool.close.size ? loadTool.close.size : 25) + "px" cl.style.height = (loadTool.close.size ? loadTool.close.size : 25) + "px" cl.style.cursor = "pointer"; cl.style.overflow="hidden"; cl.addEventListener('click',function(){ document.getElementById("basePopping").remove(); localStorage.setItem("disabledTimeClose", new Date().getTime() / 1000); }); } else { cl=document.getElementById('closebtn')[0]; } document.getElementById("basePopping").append(cl); } if(loadTool.bubble != false) { drawBubble(); } play(); } } else { console.log("popping desactivate due to no loadtool"); } } async function play(){ try { //Gestion de l'iterateur en cas de lancement du mode random if(loadTool.playtype && loadTool.playtype == 'random') { if( randomAnims && randomAnims.length == 0) { randomAnims = [...Array(loadTool.anims.length).keys()] } rand = Math.floor(Math.random() * randomAnims.length); iterator = randomAnims[rand] randomAnims.splice(rand,1) } else { iterator++ if(iterator == loadTool.anims.length) { iterator=0 } } video.src = ""; if(video.canPlayType('video/mp4; codecs="hvc1"')) { video.src = (loadTool.path ? loadTool.path:config.path)+loadTool.anims[iterator].id + ".mp4"; video.type='video/mp4; codecs="hev1"'; } else { video.src = (loadTool.path ? loadTool.path:config.path)+loadTool.anims[iterator].id + ".webm"; video.type='video/webm;'; } let style = "position:fixed;z-index:10000;line-height:0;"; if( Number.isInteger( (loadTool.fade != undefined ? loadTool.fade : config.fade))) { style+= 'animation:fadeIn '+(loadTool.fade != undefined ? loadTool.fade : config.fade)+'ms, fadeout '+(loadTool.fade != undefined ? loadTool.fade : config.fade)+'ms 10s; '; style+= 'transition: fadeIn '+(loadTool.fade != undefined ? loadTool.fade : config.fade)+'ms ease 0s;' style+= 'animation-fill-mode: forwards;'; } let transform = ""; positionY = loadTool.anims[iterator].posY != undefined ? loadTool.anims[iterator].posY : loadTool.posY positionX = loadTool.anims[iterator].posX != undefined ? loadTool.anims[iterator].posX : loadTool.posX scale = loadTool.anims[iterator].scale != undefined ? loadTool.anims[iterator].scale : (loadTool.scale != undefined ? loadTool.scale : 1) scale = (scale > 1 ? 1 :scale); scale = (scale < 0.4 ? 0.4 : scale); transform += ' scale('+scale+') '; style += 'transform-origin: bottom right;-webkit-transform-origin:bottom right;' switch (positionY) { case "top" : style+="top: 0%;"; break; case "center" : transform += 'translateY(50%) '; style+="bottom: 50%;"; break; case "bottom" : default : style+="bottom: 0%;"; break; } switch (positionX) { case "left" : style+="left: 0%;"; break; case "center" : transform += 'translateX(-50%) '; style+="left: 50%;"; break; case "right" : default : style+="right: 0%;"; break; } style+= 'transform:'+transform+';'; style+= '-webkit-transform:'+transform+';'; document.getElementById("basePopping").style="" window.setTimeout(function() { document.getElementById("basePopping").style=style },50) //Si la vidéo courante ne charge pas => on arrête la diffusion et on passe dans le mode erreur fallback video.load() var promise = video.play(); promise.then ( e => { //Add fade out after vidéo is load // console.log("duration calcule"); // console.log(video.duration); // console.log(loadTool.fade != undefined ? loadTool.fade : config.fade); // console.log(Number(video.duration)-(loadTool.fade != undefined ? loadTool.fade : config.fade)/1000); duration = Number(video.duration)-(loadTool.fade != undefined ? loadTool.fade : config.fade)/1000; document.getElementById("basePopping").style.animationDelay="0s,"+ duration + "s"; //console.log(document.getElementById("basePopping").style.animationDelay) }).catch (error => { console.error(error) setTimeout(()=>{video.play()},50); }) } catch (e){ document.getElementById("basePopping").style.visibility='hidden' console.error(e) let a = document.createElement("a"); a.id="outlink" a.href = (loadTool.outlink ? loadTool.outlink : config.outlink); if(a.href.indexOf('%C%') > 1) { a.href = a.href.replace('%C%',loadTool.anims[iterator]['card']) } if(a.href.indexOf('%M%') > 1) { a.href = a.href.replace('%M%',"m"+loadTool.anims[iterator]['model']) } a.target="_blank" let img = document.createElement("img"); img.src = config.fallbackImage; img.style.position ='fixed'; img.style.zIndex = '999999'; img.style.bottom = '0px'; img.style.cursor = 'pointer'; img.style.border = 'none'; if(config.fallbackPosition == 'center') { img.style.left = '50%'; img.style.marginLeft = '-'+parseInt(config.fallbackSize/2)+'px'; } if(config.fallbackPosition == 'left') { img.style.left = config.offset+'px'; } if(config.fallbackPosition == 'right') { img.style.right = config.offset+'px'; } img.style.width = config.fallbackSize+'px'; img.style.height = parseInt(config.fallbackSize*280/223)+'px'; a.append(img); document.getElementsByTagName('body')[0].append(a); setTimeout(play(),10000); document.getElementById("outlink").remove(); } } function alpha(event,video) { //Création du canvas et recopie de l'image let canvas = document.createElement("canvas") canvas.id ="canvas"; //canvas.style.zIndex = 99 canvas.crossOrigin="anonymous" ctx = canvas.getContext("2d"); ctx.imageSmoothingEnabled = true ctx.imageSmoothingQuality = 'medium'; ctx.clearRect(0, 0, 1, 1); ctx.drawImage( video, event.clientX - video.offsetParent.offsetLeft + (loadTool.anims[iterator].posX == 'center' || loadTool.posX == 'center' ? video.videoWidth/2 : 0), //x coordinate event.clientY - video.offsetParent.offsetTop - (loadTool.anims[iterator].posY == 'center' ? video.videoHeight/2 : 0), //y coordinate 1, // width to copy 1, // height to copy 0, //x coordinate where to place the img on canvas 0, //y coordinate where to place the img on canvas 1, //width of the img to use 1, // height of the img to use ); //Calcule de la position du click dans le canvas. A ajuster en fonction de la transformation css return ctx.getImageData( 0, 0, 1, 1 ).data[3]; } function drawBubble (){ let bubble = document.createElement('div'); bubble.style= "position: absolute; left: auto; width: auto; top: 0px; right: 50%;"; let inside_bubble = document.createElement('div'); inside_bubble.style = 'position: relative; left: auto; top: -50px; height: 40px; background: rgb(231, 46, 74); z-index: 10001; margin: 0px auto; border-radius: 10px; pointer-events: none; color: rgb(255, 255, 255); font: 700 18px / 42px Arial; text-align: center; padding: 0px 15px; white-space: nowrap;-webkit-transform:scale(1); transform: scale(1); right: -50%;' inside_bubble.style.animation = '1s linear 0s infinite normal both running TotemToolbounce, 7s linear 0s infinite normal both running TotemToolFade' if(loadTool.bubble != undefined) { if(loadTool.bubble.color != undefined) { inside_bubble.style.background = loadTool.bubble.color } if(loadTool.bubble.radius != undefined) { inside_bubble.style.borderRadius= loadTool.bubble.radius } if(loadTool.bubble.size != undefined) { inside_bubble.style.transform.scale = loadTool.bubble.size } inside_bubble.textContent = (loadTool.bubbleText ? loadTool.bubbleText : config.bubbleText) if(!loadTool.bubble.noSpeech) { let speech = document.createElement('div'); speech.style="position: absolute; width: 0px; height: 0px; bottom: -8px; left: 10px; border-style: solid solid none; border-width: 8px 8px 0px; border-color: rgb(231, 46, 74) transparent currentcolor; border-image: none 100% / 1 / 0 stretch;" inside_bubble.append(speech); } bubble.append(inside_bubble); document.getElementById("basePopping").append(bubble); } } setTimeout( () => { if(mobileAction == 'No' && mobileDevice ) {//do nothing } else { if(!mobileDevice || mobileAction == 'Yes' ) { init(); } else { loadTool=loadToolMobile; init(); } } },100) }; popping_function();

ODSYŁACZ VIDEO OBRAZKOWY

Favorite Body Parts Maldives

Menu obrazkowe REKLAMA

ZDJĘCIE

IRINA SHEYK