>웹 프론트엔드 >CSS 튜토리얼 >CSS를 사용하여 팩맨 로딩 효과 구현

CSS를 사용하여 팩맨 로딩 효과 구현

青灯夜游
青灯夜游앞으로
2022-01-05 10:18:182644검색

이 기사에서는 순수 CSS를 사용하여 팩맨의 로딩 효과를 얻는 방법을 소개합니다. 모든 사람에게 도움이 되기를 바랍니다.

CSS를 사용하여 팩맨 로딩 효과 구현

CSS는 정말 터무니없을 만큼 매력적입니다. 아마도 최근 제 글을 팔로우하신 분들은 제가 CSS 관련 글을 많이 냈다는 걸 아실 겁니다. 인터넷에서 이런 효과를 보고 직접 복사한 분들도 계실 텐데요. 방금 본 지식 포인트를 활용해서 재미있는 것들을 만들어 보세요. CSS는 정말 재미있습니다!

오늘 제가 가져온 퍼포먼스의 아이디어는 제 블로그의 친구 링크 페이지에서 따왔습니다. 다른 사람의 아바타에 대한 리소스를 요청할 수 없다면 Pac-Man 로딩을 추가하겠습니다. 올라가서 오늘 가져온 퍼포먼스는 바로 이 팩맨이에요~吃豆人的Loading上去,而这个吃豆人,就是我今天带来的表演~

CSS를 사용하여 팩맨 로딩 효과 구현

实现吃豆人的大嘴巴

先来实现左边的大嘴巴,我是用了两个这种形状的东西,完后给下面的那个margin-top:-50px,它俩就实现了重叠,之后用动画效果,让上面顺时针旋转,下方与之相反,旋转90°就可以实现嘴巴张开合上的动作了。

CSS를 사용하여 팩맨 로딩 효과 구현

    width: 0px;
    height: 0px;
    border-right: 25px solid transparent;
    border-top: 25px solid #279fcf;
    border-left: 25px solid #279fcf;
    border-bottom: 25px solid #279fcf;
    border-radius: 25px;

旋转动画分别是:

@keyframes rotate_pacman_up {
  0% {
    -webkit-transform: rotate(270deg);
            transform: rotate(270deg); }

  50% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg); }

  100% {
    -webkit-transform: rotate(270deg);
            transform: rotate(270deg); } 
}
@keyframes rotate_pacman_down {
  0% {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg); 
     }

  50% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
      }

  100% {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
       } 
}

之后将动画加到我们刚刚生成的那两个元素的css中即可(运用这个属性就行:animation),因为我是div套了div,所以我用的是伪元素来选择的:分别是first-of-typenth-child(2),选中了第一个跟第二个div来作为吃豆人的嘴巴。

要注意的是,两个嘴巴的动画时间要同步,否则这个嘴可就上下乱窜了:

    animation: rotate_pacman_up 0.75s 0s infinite

现在的效果是这样的:

CSS를 사용하여 팩맨 로딩 효과 구현

实现吃豆人的豆子

同样,我们在刚刚的两个div同级的地方,又建了三个div,我真是太喜欢div了~

万物皆可div!!!

豆子相对于嘴巴来说就很简单,首先他是圆的,其次呢,它的动画是向左移动的,具备这两个条件,就可以了。我们直接使用伪元素选中3、4、5三个div,加上这段css即可。

    background-color: #279fcf;
    width: 15px;
    height: 15px;
    border-radius: 100%;
    margin: 2px;
    width: 10px;
    height: 10px;
    position: absolute;
    transform: translate(0, -6.25px);
    top: 25px;
    left: 100px;

会不会有人问:为什么你就知道定位的时候是-6.25px呢?,最后解释最后解释。

接下来加上向左移动的动画:

@keyframes pacman-balls {
  75% {
    opacity: 0.7; }

  100% {
    -webkit-transform: translate(-100px, -6.25px);
            transform: translate(-100px, -6.25px); } 
}

似乎,要是走一段变得透明一些是不是会更好?这个有待考虑~

最后将动画分别用选择器挂到第3、4、5个div

CSS를 사용하여 팩맨 로딩 효과 구현

팩맨의 큰 입을 구현

CSS를 사용하여 팩맨 로딩 효과 구현

먼저 알아두자 왼쪽의 큰 입은 이 모양의 두 가지를 사용했고, 완성 후 아래의 것을 margin-top:-50px 로 겹쳐서 애니메이션 효과를 사용했습니다. 위쪽을 시계 방향으로 회전하고, 아래쪽을 90° 회전하여 입을 열고 닫습니다.

CSS를 사용하여 팩맨 로딩 효과 구현

    animation: pacman-balls 1s 0.33/0.66/0.99s infinite linear

회전 애니메이션은 다음과 같습니다.

rrreeerrreeeCSS를 사용하여 팩맨 로딩 효과 구현 그런 다음 방금 생성한 두 요소의 CSS에 애니메이션을 추가합니다(animation 속성 사용). 왜냐하면 저는 div이기 때문입니다. <code>div로 설정했으므로 의사 요소를 사용하여 first-of-typenth-child(2), 첫 번째 및 두 번째 <code>div는 팩맨의 입으로 선택됩니다.

두 입의 애니메이션 시간을 동기화해야 합니다. 그렇지 않으면 입이 위아래로 움직입니다. rrreee현재 효과는 다음과 같습니다.

🎜CSS를 사용하여 팩맨 로딩 효과 구현🎜

Pac 구현- 🎜🎜마찬가지로 div 두 개와 같은 레벨에 div 세 개를 더 만들었어요. div >이제~🎜
🎜모든 것이 div가 될 수 있습니다! ! ! 🎜
🎜빈은 입에 비해 매우 단순하고, 둘째, 이 두 가지 조건이 충족되면 애니메이션이 왼쪽으로 이동합니다. 의사 요소를 직접 사용하여 세 개의 div 3, 4, 5를 선택하고 이 CSS를 추가합니다. 🎜rrreee
🎜누가 물어보겠습니까? 위치 지정이 -6.25px라는 것을 왜 아나요? , 마지막 설명이 마지막 설명입니다. 🎜
🎜 다음으로 왼쪽으로 이동하는 애니메이션을 추가합니다. 🎜rrreee🎜 잠시 투명해지면 더 좋을 것 같은데요? 이 점을 고려해야 합니다~🎜🎜마지막으로 선택기를 사용하여 3번째, 4번째, 5번째 div에 애니메이션을 걸면 됩니다. 동시에 시작 시간을 설정하지 않도록 주의하세요. 애니메이션을 동일하게 설정하고, 그렇지 않으면 이제 동기화됩니다! ! ! 여기서 제가 설정한 설정은 각각 0.33/0.66/0.99초 입니다~ 이렇습니다: 🎜rrreee🎜최종 효과 좀 보세요~🎜🎜🎜🎜🎜그건 -6.25px🎜🎜사실... 오랫동안 공부했는데 계산해보시면 사진 드리겠습니다. 도와주세요.. 계산해본 결과 드디어 실험을 통해 얻었습니다. 6~7은 거의 동일하지만 6.25가 눈에 더 즐겁습니다. 그러나 실험이 7px에 도달하면 작은 원의 중심이 분명하게 나타납니다. 조금 높으니 emm이 6.25네요(약~, 그리고 6.5도 쓰고 싶었는데 항상 6.25가 더 좋은 것 같아요 emm). 🎜🎜🎜🎜🎜(동영상 공유 학습: 🎜css 동영상 튜토리얼🎜)🎜

위 내용은 CSS를 사용하여 팩맨 로딩 효과 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 juejin.cn에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제