ViewTimeline
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
Experimental: ããã¯å®é¨çãªæ©è½ã§ãã
æ¬çªã§ä½¿ç¨ããåã«ãã©ã¦ã¶ã¼äºææ§ä¸è¦§è¡¨ããã§ãã¯ãã¦ãã ããã
ViewTimeline ã¯ã¦ã§ãã¢ãã¡ã¼ã·ã§ã³ API ã§ããã¥ã¼é²æã©ã¤ã ã©ã¤ã³ã表ãã¾ãï¼è©³ãã㯠CSS ã¹ã¯ãã¼ã«é§åã¢ãã¡ã¼ã·ã§ã³ãåç
§ãã¦ãã ããï¼ã
ViewTimeline ã¤ã³ã¹ã¿ã³ã¹ã Animation() ã³ã³ã¹ãã©ã¯ã¿ã¼ã¾ã㯠animate() ã¡ã½ããã«æ¸¡ãã¨ãã¢ãã¡ã¼ã·ã§ã³ã®é²è¡ãå¶å¾¡ããã¿ã¤ã ã©ã¤ã³ã¨ãã¦æå®ãã¾ãã
ã³ã³ã¹ãã©ã¯ã¿ã¼
ViewTimeline()-
æ°ãã
ViewTimelineãªãã¸ã§ã¯ãã¤ã³ã¹ã¿ã³ã¹ã使ãã¾ãã
ã¤ã³ã¹ã¿ã³ã¹ããããã£
親ã§ãã ScrollTimeline ããç¶æ¿ããããããã£ãããã¾ãã
subjectèªåå°ç¨-
æãè¿ãç¥å ã®ã¹ã¯ãã¼ã«å¯è½è¦ç´ ï¼ã¹ã¯ãã¼ã©ã¼ï¼å ã®å¯è¦æ§ãã¿ã¤ã ã©ã¤ã³ã®é²è¡ãã¤ã¾ãã¢ãã¡ã¼ã·ã§ã³ãé§åãã¦ãã主ä½è¦ç´ ã¸ã®åç §ãè¿ãã¾ãã
startOffsetèªåå°ç¨-
ã¿ã¤ã ã©ã¤ã³ã®ã¹ã¯ãã¼ã«éå§ä½ç½®ï¼é²è¡åº¦ 0%ï¼ã表ã
CSSNumericValueããã¹ã¯ãã¼ã©ã¼å ã®ã³ã³ãã³ãã®ãªã¼ãã¼ããã¼ããåºéã®éå§ä½ç½®ããã®ãªãã»ããã¨ãã¦è¿ãã¾ãã endOffsetèªåå°ç¨-
ã¿ã¤ã ã©ã¤ã³ã®ã¹ã¯ãã¼ã«ã®çµããï¼é²è¡åº¦ 100%ï¼ã®ä½ç½®ããã¹ã¯ãã¼ã©ã¼å ã®ã³ã³ãã³ããæº¢ããåºéã®éå§ä½ç½®ããã®ãªãã»ããã¨ãã¦è¡¨ã
CSSNumericValueãè¿ãã¾ãã
ã¤ã³ã¹ã¿ã³ã¹ã¡ã½ãã
ãã®ã¤ã³ã¿ã¼ãã§ã¤ã¹ã«ã¯ã親ã§ãã ScrollTimeline ããç¶æ¿ããã¡ã½ãããããã¾ãã
ä¾
>ãã¥ã¼é²è¡ã¿ã¤ã ã©ã¤ã³ã®ä¸»ä½ã¨ãªãã»ããã®è¡¨ç¤º
ãã®ä¾ã§ã¯ããã¥ã¼é²è¡ã¿ã¤ã ã©ã¤ã³ã«æ²¿ã£ã¦ class ã subject ã®è¦ç´ ãã¢ãã¡ã¼ã·ã§ã³ãã¦ãã¾ã - ææ¸ãã¹ã¯ãã¼ã«ããªãã䏿¹åã«ç§»åãããã¨ã¢ãã¡ã¼ã·ã§ã³ãã¾ããã¾ããsubject, startOffset, endOffset ã®å¤ãå³ä¸ã® output è¦ç´ ã«åºåãã¦ãã¾ãã
HTML
ä¾ã® HTML ã¯ä¸è¨ã®ã¨ããã§ãã
<div class="content">
<h1>Content</h1>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
tempor incididunt ut labore et dolore magna aliqua. Risus quis varius quam
quisque id. Et ligula ullamcorper malesuada proin libero nunc consequat
interdum varius. Elit ullamcorper dignissim cras tincidunt lobortis feugiat
vivamus at augue.
</p>
<p>
Dolor sed viverra ipsum nunc aliquet. Sed risus pretium quam vulputate
dignissim. Tortor aliquam nulla facilisi cras. A erat nam at lectus urna
duis convallis convallis. Nibh ipsum consequat nisl vel pretium lectus.
Sagittis aliquam malesuada bibendum arcu vitae elementum. Malesuada bibendum
arcu vitae elementum curabitur vitae nunc sed velit.
</p>
<div class="subject animation"></div>
<p>
Adipiscing enim eu turpis egestas pretium aenean pharetra magna ac. Arcu
cursus vitae congue mauris rhoncus aenean vel. Sit amet cursus sit amet
dictum. Augue neque gravida in fermentum et. Gravida rutrum quisque non
tellus orci ac auctor augue mauris. Risus quis varius quam quisque id diam
vel quam elementum. Nibh praesent tristique magna sit amet purus gravida
quis. Duis ultricies lacus sed turpis tincidunt id aliquet. In egestas erat
imperdiet sed euismod nisi. Eget egestas purus viverra accumsan in nisl nisi
scelerisque. Netus et malesuada fames ac.
</p>
<div class="output"></div>
</div>
CSS
ä¾ã® CSS ã¯ä¸è¨ã®ã¨ããã§ãã
.subject {
width: 300px;
height: 200px;
margin: 0 auto;
background-color: deeppink;
}
.content {
width: 75%;
max-width: 800px;
margin: 0 auto;
}
.output {
position: fixed;
top: 5px;
right: 5px;
}
p,
h1,
div {
font-family: Arial, Helvetica, sans-serif;
}
h1 {
font-size: 3rem;
}
p {
font-size: 1.5rem;
line-height: 1.5;
}
JavaScript
JavaScript ã§ subject 㨠output ã® <div> ã®åç
§ãåå¾ããæ°ãã ViewTimeline ã使ããããã subject è¦ç´ ã«é¢é£ä»ããã¿ã¤ã ã©ã¤ã³ã®é²è¡ããã®ã¹ã¯ãã¼ã«ããå
ç¥ãéãã¦ãã®è¦ç´ ã®å¯è¦æ§ã«åºã¥ãã¦ãããã¨ãæå®ããblock 軸ãè¨å®ããinset å¤ãè¨å®ãã¦ã主ä½ã表示ããã¦ããã¨ã¿ãªãããããã¯ã¹ã®ä½ç½®ã調æ´ãã¾ãã
ããã¦ãã¦ã§ãã¢ãã¡ã¼ã·ã§ã³ API ã使ã£ã¦ subject è¦ç´ ãã¢ãã¡ã¼ã·ã§ã³ãã¾ããæå¾ã«ãsubjectãstartOffsetãendOffset ã®å¤ã output è¦ç´ ã«è¡¨ç¤ºãã¾ãã
const subject = document.querySelector(".subject");
const output = document.querySelector(".output");
const timeline = new ViewTimeline({
subject,
axis: "block",
inset: [CSS.px("200"), CSS.px("300")],
});
subject.animate(
{
opacity: [0, 1],
transform: ["scaleX(0)", "scaleX(1)"],
},
{
fill: "both",
timeline,
},
);
output.textContent += `Subject element: ${timeline.subject.nodeName}, `;
output.textContent += `start offset: ${timeline.startOffset}, `;
output.textContent += `end offset: ${timeline.endOffset}.`;
çµæ
ã¹ã¯ãã¼ã«ããã¨ãã¢ãã¡ã¼ã·ã§ã³ãã主ä½è¦ç´ ã表示ããã¾ãã
仿§æ¸
| Specification |
|---|
| Scroll-driven Animations > # viewtimeline-interface > |