Ich versuche, ein kleines Plugin zu schreiben, um Modal-Boxen auf eine organischere Weise zu öffnen, deshalb habe ich beschlossen, die Clip-Pfad-Eigenschaft zu animieren.Verwendung von Clip-Path-Polygonen in FF und IOS
Jetzt funktioniert dieser Code nur in Chrom: http://codepen.io/meodai/pen/GgGzYo?editors=011
Es ist wie firefox does not supportpolygon()
in der Eigenschaft Klipppfad aussieht. Safari & Mobile Safari hat auch damit zu kämpfen.
Gibt es einen ähnlich einfachen Weg, um dies in Firefox und Safari und Mobile Safari auch funktionieren zu lassen? Irgendeine Idee, wie ich dieses Problem angehen könnte? Hier
ist ein funktionierendes Beispiel:
var $ov = $('.overlay');
$(document).on('click touchstart', '.inner', function(){
var coords, coordArray, coordsString;
coords = this.getBoundingClientRect();
coordArray = [
Math.floor(parseInt(coords.left)) + 'px ' + Math.floor(parseInt(coords.top)) + 'px',
Math.ceil((parseInt(coords.left) + parseInt(coords.width))) + 'px ' + Math.ceil(parseInt(coords.top)) + 'px',
Math.ceil((parseInt(coords.left) + parseInt(coords.width))) + 'px ' + Math.ceil((parseInt(coords.top) + parseInt(coords.height))) + 'px',
Math.ceil(parseInt(coords.left)) + 'px ' + Math.floor((parseInt(coords.top) + parseInt(coords.height))) + 'px'
];
coordsString = 'polygon(' + coordArray[0] + ',' + coordArray[1] + ',' + coordArray[2] + ',' + coordArray[3] + ')';
$ov.css({
'-webkit-clip-path': coordsString,
'clip-path': coordsString
});
setTimeout(function(){
$ov.addClass('show');
},50);
setTimeout(function(){
coordsString = 'polygon(0% 0%,' + coordArray[1] + ',' + coordArray[2] + ',' + coordArray[3] + ')';
$ov.css({
'-webkit-clip-path': coordsString,
'clip-path': coordsString
});
},100);
setTimeout(function(){
coordsString = 'polygon(0% 0%,100% 0%,' + coordArray[2] + ',' + coordArray[3] + ')';
$ov.css({
'-webkit-clip-path': coordsString,
'clip-path': coordsString
});
},180);
setTimeout(function(){
coordsString = 'polygon(0% 0%,100% 0%,100% 100%,' + coordArray[3] + ')';
$ov.css({
'-webkit-clip-path': coordsString,
'clip-path': coordsString
});
},260);
setTimeout(function(){
coordsString = 'polygon(0% 0%,100% 0%,100% 100%,0 100%)';
$ov.css({
'-webkit-clip-path': coordsString,
'clip-path': coordsString
});
},340);
// reverse
setTimeout(function(){
coordsString = 'polygon(0% 0%,100% 0%,100% 100%,' + coordArray[3] + ')';
$ov.css({
'-webkit-clip-path': coordsString,
'clip-path': coordsString
});
},1500);
setTimeout(function(){
coordsString = 'polygon(0% 0%,100% 0%,' + coordArray[2] + ',' + coordArray[3] + ')';
$ov.css({
'-webkit-clip-path': coordsString,
'clip-path': coordsString
});
},1580);
setTimeout(function(){
coordsString = 'polygon(0% 0%,' + coordArray[1] + ',' + coordArray[2] + ',' + coordArray[3] + ')';
$ov.css({
'-webkit-clip-path': coordsString,
'clip-path': coordsString
});
},1640);
setTimeout(function(){
coordsString = 'polygon(' + coordArray[0] + ',' + coordArray[1] + ',' + coordArray[2] + ',' + coordArray[3] + ')';
$ov.css({
'-webkit-clip-path': coordsString,
'clip-path': coordsString
});
},1740);
setTimeout(function(){
$ov.removeClass('show');
},2000);
});
body, html {
background: silver;
}
.grid {
float: left;
width: 25%;
height: 25vw;
box-shizing: border-box;
position: relative;
}
.inner {
position: absolute;
top: 10px;
left: 10px;
bottom: 10px;
right: 10px;
background: #ddd;
-webkit-transition: background-color 111ms;
transition: background-color 111ms;
}
.inner:hover {
background: #fff;
}
.overlay {
opacity: 0;
position: fixed;
top: 0;
left: 0;
bottom: 0;
right: 0;
background: #fff;
pointer-events: none;
box-sizing: border-box;
padding: 20px;
}
.overlay.show {
opacity: 1;
will-change: clip-path;
-webkit-transition: clip-path 200ms;
transition: clip-path 200ms;
-webkit-transition: -webkit-clip-path 200ms;
transition: -webkit-clip-path 200ms;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="grid">
<div class="inner"></div>
</div>
<div class="overlay"></div>
Sie könnten eine SVG für Firefox - http://caniuse.com/#search=clip-path –
@Paulie_D oh! Ich wusste nicht, dass du ein SVG als Clip-Pfad referenzieren kannst, ich werde mit diesem Dank herumspielen ... frage mich immer noch, ob es eine browserübergreifende Lösung/Hack für das gibt – meo
Hier ist ein netter kleiner Artikel [** https://css-tricks.com/clipping-masking-css/**](https://css-tricks.com/clipping-masking-css/) und diese [** Support Chart **] (http: //codepen.io/yoksel/full/fsdbu/) –