Notice: Undefined variable: root in /users/basti1012/www/index1.php on line 41
Svg Line animate arround a box

Svg Line animate arround a box

Einfach auf den Buttons klicken und ihr wisst, was ich meine. Wenn ich mich recht erinnere, war das mal eine Lösung von @sempervivum , nur leider finde ich das Theme nicht mehr wieder. Ich glaube das der Code komplett von ihm war , kann aber sein das ich ihn etwas geändert hatte

Der hier verwendete Code

<!DOCTYPE html> <html lang="de"> <head> <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <style> body { background-color: #181a27; } #conti{ display:flex; } #conti ul li{ list-style:none; color:white; font-size:20px; margin-top:35px; } svg { position:absolute; z-index:1; top:15px; margin-left:25px; display:none; } #box{ position:relative; z-index:10; width:250px; height:250px; left:50px; top:40px; font-size:25px; color:white; } span{ display:flex; flex:1; flex-direction:row; } li{ width:100%; display:inline-block; margin-top:20px; padding-left:30px; border-bottom:5px solid transparent; font-size:30px; color:white; } #right,#left{ flex:1; } </style> </head> <body> <div id="conti"> <div id="left"> <li data-text="hallo steht lorem ipsum und mehr">Text 1</li> <li data-text="hallo hier könnte dein text stehen und noch viel mehr">Text 2</li> <li data-text="hier steht nur bla bla blub">Text 3</li> <li data-text="und hier machen wir mal werbung rein ">Text 4</li> <li>Text 5</li> </div> <div id="right"> <div id="box"></div> <svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="400px" height="400px" > <rect x="10" y="10" fill="none" stroke="#ffffff" stroke-width="10" stroke-miterlimit="10" width="300" height="300"/> </svg> <div> </div> <script> function go(){ jQuery.extend( jQuery.easing, { easeInOutQuad: function (x, t, b, c, d) { if ((t/=d/2) < 1) return c/2*t*t + b; return -c/2 * ((--t)*(t-2) - 1) + b; } }); function SVG(tag) { return document.createElementNS('http://www.w3.org/2000/svg', tag); } function replaceRectsWithPaths(parentElement) { var rects = $(parentElement).find('rect'); $.each(rects, function() { var rectX = $(this).attr('x'); var rectY = $(this).attr('y'); var rectX2 = parseFloat(rectX) + parseFloat($(this).attr('width')); var rectY2 = parseFloat(rectY) + parseFloat($(this).attr('height')); var convertedPath = 'M' + rectX + ',' + rectY + ' ' + rectX2 + ',' + rectY + ' ' + rectX2 + ',' + rectY2 + ' ' + rectX + ',' + rectY2 + ' ' + rectX + ',' + rectY; $(SVG('path')) .attr('d', convertedPath) .attr('fill', $(this).attr('fill')) .attr('stroke', $(this).attr('stroke')) .attr('stroke-width', $(this).attr('stroke-width')) .insertAfter(this); }); $(rects).remove(); } function hideSVGPaths(parentElement){ var paths = $(parentElement).find('path'); $.each( paths, function() { var totalLength = this.getTotalLength(); $(this).css({ 'stroke-dashoffset': totalLength, 'stroke-dasharray': totalLength + ' ' + totalLength }); }); } function drawSVGPaths(_parentElement, _timeMin, _timeMax, _timeDelay) { var paths = $(_parentElement).find('path'); $.each( paths, function(i) { var totalLength = this.getTotalLength(); $(this).css({ 'stroke-dashoffset': totalLength, 'stroke-dasharray': totalLength + ' ' + totalLength }); $(this).delay(_timeDelay*i).animate({ 'stroke-dashoffset': 0 }, { duration: Math.floor(Math.random() * _timeMax) + _timeMin ,easing: 'easeInOutQuad' }); }); } function startSVGAnimation(parentElement){ replaceRectsWithPaths(parentElement); drawSVGPaths(parentElement, 100, 1000, 50); } startSVGAnimation($('svg')); } $('li').click(function(){ $('li').css('border-bottom','5px solid transparent'); $(this).css('border-bottom','5px solid white') g=$(this).data('text'); $('#box').html(''); setTimeout(function(){ $('#box').html(g); },1000); $('svg').css('display','block'); go() }) </script> </body> </html>