> 웹 프론트엔드 > JS 튜토리얼 > CSS를 사용하여 탁구 격투 애니메이션 구현

CSS를 사용하여 탁구 격투 애니메이션 구현

php中世界最好的语言
풀어 주다: 2018-05-24 10:55:08
원래의
1872명이 탐색했습니다.

이번에는 CSS를 사용하여 탁구 격투 애니메이션을 구현하는 방법을 소개하겠습니다. CSS를 사용하여 탁구 격투 애니메이션을 구현하는 주의 사항은 다음과 같습니다.

코드 해석

돔 정의, 컨테이너에는 왼쪽 라켓, 작은 공 및 오른쪽 라켓이 포함됩니다.

<p class="court">
    <p class="left-paddle"></p>
    <p class="ball"></p>
    <p class="right-paddle"></p>
</p>
로그인 후 복사

중앙 디스플레이:

body {
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(silver, dimgray);
}
로그인 후 복사

조정 박스 모델:

* {
    box-sizing: border-box;
}
로그인 후 복사

공 케이스 그리기:

.court {
    width: 20em;
    height: 20em;
    color: white;
    border: 1em solid currentColor;
}
로그인 후 복사

왼쪽 그리기 슛:

.court {
    position: relative;
}
.left-paddle
    width: 1em;
    height: calc(50% - 1em);
    background-color: currentColor;
    position: absolute;
    top: 1em;
    left: 1em;
}
로그인 후 복사

왼쪽 라켓을 움직이게 합니다:

.left-paddle {
    animation: left-moving 1s linear infinite alternate;
}
@keyframes left-moving {
    to {
        transform: translateY(100%);
    }
}
로그인 후 복사

마찬가지로 오른쪽 라켓을 그립니다:

.right-paddle
    width: 1em;
    height: calc(50% - 1em);
    background-color: currentColor;
    position: absolute;
    top: 1em;
    left: 1em;
    bottom: 1em;
    right: 1em;
}
로그인 후 복사

마찬가지로 오른쪽 라켓을 그립니다:

.right-paddle {
    animation: right-moving 1s linear infinite alternate;
}
@keyframes right-moving {
    to {
        transform: translateY(-100%);
    }
}
로그인 후 복사

공을 그립니다:

.ball {
    width: 100%;
    height: 1em;
    border-left: 1em solid currentColor;
    position: absolute;
    left: 2em;
    top: calc(50% - 1.5em);
}
로그인 후 복사

공을 움직입니다:

.ball {
    animation: bounce 1s linear infinite alternate;
}
@keyframes bounce {
    to {
        left: calc(100% - 3em);
    }
}
로그인 후 복사

마지막으로 , 왼쪽 및 오른쪽 촬영 코드를 리팩터링하고 공통 속성을 병합합니다.

.left-paddle,
.right-paddle {
    width: 1em;
    height: calc(50% - 1em);
    background-color: currentColor;
    position: absolute;
    animation: 1s linear infinite alternate;
}
.left-paddle {
    top: 1em;
    left: 1em;
    animation-name: left-moving;
}
.right-paddle {
    bottom: 1em;
    right: 1em;
    animation-name: right-moving;
}
로그인 후 복사

완료되었습니다!

이 기사의 사례를 읽은 후 방법을 마스터했다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!

추천 도서:

Chart.js 경량 차트 라이브러리 사용 사례 분석

Node.js의 https 사용 사례 분석

위 내용은 CSS를 사용하여 탁구 격투 애니메이션 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
css
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿