I have this stylesheet:
        @-webkit-keyframes run {             0% {                 -webkit-transform: translate3d(0px, 0px, 0px);             }                         100% {                 -webkit-transform: translate3d(0px, 1620px, 0px);             }         }   Now, I would like to modify the value of 1620px depending on some parameters. Like this:
        @-webkit-keyframes run {             0% {                 -webkit-transform: translate3d(0px, 0px, 0px);             }                         100% {                 -webkit-transform: translate3d(0px, height*i, 0px);             }         }   I would prefer to be able to use JavaScript and jQuery, though a pure CSS solution would be ok.
This is for an iPhone game that runs in it's mobile Apple Safari browser.
var style = document.documentElement.appendChild(document.createElement("style")), rule = " run {\     0%   {\         -webkit-transform: translate3d(0, 0, 0); }\         transform: translate3d(0, 0, 0); }\     }\     100% {\         -webkit-transform: translate3d(0, " + your_value_here + "px, 0);\         transform: translate3d(0, " + your_value_here + "px, 0);\     }\ }"; if (CSSRule.KEYFRAMES_RULE) { // W3C     style.sheet.insertRule("@keyframes" + rule, 0); } else if (CSSRule.WEBKIT_KEYFRAMES_RULE) { // WebKit     style.sheet.insertRule("@-webkit-keyframes" + rule, 0); }   If you want to modify a keyframe rule in a stylesheet that's already included, do the following:
var       stylesheet = document.styleSheets[0] // replace 0 with the number of the stylesheet that you want to modify     , rules = stylesheet.rules     , i = rules.length     , keyframes     , keyframe ;  while (i--) {     keyframes = rules.item(i);     if (         (                keyframes.type === keyframes.KEYFRAMES_RULE             || keyframes.type === keyframes.WEBKIT_KEYFRAMES_RULE         )         && keyframes.name === "run"     ) {         rules = keyframes.cssRules;         i = rules.length;         while (i--) {             keyframe = rules.item(i);             if (                 (                        keyframe.type === keyframe.KEYFRAME_RULE                     || keyframe.type === keyframe.WEBKIT_KEYFRAME_RULE                 )                 && keyframe.keyText === "100%"             ) {                 keyframe.style.webkitTransform =                 keyframe.style.transform =                     "translate3d(0, " + your_value_here + "px, 0)";                 break;             }         }         break;     } }   If you don't know the order but do know the URL of the CSS file, replace document.styleSheets[0] with document.querySelector("link[href='your-css-url.css']").sheet.
Have you tried declaring the keyframe portion of your css in a <style> element in the head of your html document. You can then give this element an id or whatever and change it's content whenever you like with javaScript. Something like this:
<style id="keyframes">         @-webkit-keyframes run {             0%    { -webkit-transform: translate3d(0px,0px,0px); }                         100%  { -webkit-transform: translate3d(0px, 1620px, 0px); }         } </style>   Then your jquery can change this as normal:
$('#keyframes').text('whatever new values you want in here'); 
                        If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With