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();