Heim > Web-Frontend > CSS-Tutorial > Codebeispiele für die Implementierung von Spezialeffekten für 3D-Animationen mithilfe von CSS

Codebeispiele für die Implementierung von Spezialeffekten für 3D-Animationen mithilfe von CSS

不言
Freigeben: 2018-08-13 15:29:52
Original
4375 Leute haben es durchsucht

Der Inhalt dieses Artikels befasst sich mit Codebeispielen für die Realisierung von 3D-Animationsspezialeffekten. Ich hoffe, dass er für Sie hilfreich ist.

Lassen Sie uns zunächst ein Rendering betrachten

1.1.1

Codebeispiele für die Implementierung von Spezialeffekten für 3D-Animationen mithilfe von CSS

Attribute

Perspektive: Perspektivischer Abstand, Einheitspixel (je kleiner der Wert, je näher der perspektivische Abstand, desto offensichtlicher der Effekt): Legen Sie das übergeordnete Element fest

perspective-origin: Legen Sie die Position des perspektivischen Punkts fest

transform -style: gibt an, dass sich die untergeordneten Elemente eines Elements im dreidimensionalen Raum befinden, Wert: flat | Preserve-3d

1.1.1 Idee

(1 ) Es gibt drei P's, pack sie in eine Box.

1

2

3

4

5

6

7

  <p>

            </p><p>

                </p><p></p>

                <p></p>

                <p></p>

             

         

Nach dem Login kopieren

(2) Legen Sie den Stil für die Box fest

1

2

3

4

5

6

7

8

9

10

11

.cube{

        width: 200px;

        height: 300px;

        transform-style: preserve-3d;

        margin:100px auto;

        

        position: relative;

        transform: rotateX(30deg);

        border-radius: 50%;

            padding: 60px;

    }

Nach dem Login kopieren

(3) Legen Sie den Stil für jedes p davon fest

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

 .mian{

        width: 200px;

        height: 300px;

        background-image: url(1.jpg);

        background-position:400px 0;

        position: absolute;

        background: url(aka.jpg);

        border: 1px solid #ccc;

        transition: 2s;

    }

    /* .mian1:hover{

        transform-origin: right;

        transform: rotateY(-60deg);

    } */

    .mian1{

        transform-origin: right;

        transform: translateX(-200px) rotateY(45deg);

        background-position:0 0;

    }

 

    .mian2{

        background-position: 400px 0;

    }

 

    .mian3{

        transform-origin: left;

        transform: translateX(200px) rotateY(45deg);

        background-position: 200px 0;

    }

Nach dem Login kopieren

(4) Animation dafür festlegen

1

2

3

4

5

6

 .mian3:hover{

        transform: translateX(200px) rotateY(0deg);

    

    .mian1:hover{

        transform: translateX(-200px) rotateY(0deg);

    }

Nach dem Login kopieren

1.1.1 Quellcode:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

nbsp;html>

 

 

    <meta>

    <meta>

    <meta>

    <title>书页</title>

    <style>

        .container{

            width: 1000px;

            height: 650px;

      

            perspective: 2000px;

            border: 1px solid transparent;

            overflow: hidden;

            margin: 0 auto;

            perspective-origin: 10% 20%;

            

        }

     

        .cube{

            width: 200px;

            height: 300px;

            transform-style: preserve-3d;

            margin:100px auto;

            

            position: relative;

            transform: rotateX(30deg);

            border-radius: 50%;

            padding: 60px;

        }

        .mian{

            width: 200px;

            height: 300px;

            background-image: url(1.jpg);

            background-position:400px 0;

            position: absolute;

            background: url(aka.jpg);

            border: 1px solid #ccc;

            transition: 2s;

        }

        /* .mian1:hover{

            transform-origin: right;

            transform: rotateY(-60deg);

        } */

        .mian1{

            transform-origin: right;

            transform: translateX(-200px) rotateY(45deg);

            background-position:0 0;

        }

 

        .mian2{

            background-position: 400px 0;

        }

 

        .mian3{

            transform-origin: left;

            transform: translateX(200px) rotateY(45deg);

            background-position: 200px 0;

        }

        .mian3:hover{

            transform: translateX(200px) rotateY(0deg);

        }

        .mian1:hover{

            transform: translateX(-200px) rotateY(0deg);

        }

    </style>

 

 

    <p>

        </p><p>

            </p><p></p>

            <p></p>

            <p></p>

         

     

Nach dem Login kopieren

1.1.2

Codebeispiele für die Implementierung von Spezialeffekten für 3D-Animationen mithilfe von CSS

1.1.2 Idee:

(1) Es gibt fünf P's, setze fünf Wörter in jedem.

1

2

3

4

5

6

7

  <p>

        </p><p>前</p>

        <p>端</p>

        <p>小</p>

        <p>学</p>

        <p>生</p>

     

Nach dem Login kopieren

(2) Gesamtstile für Box und P festlegen

1

2

3

4

5

6

7

8

9

10

11

12

 #box{

        margin: 100px auto;

        font-size: 100px;

        color:#005aa0;

        text-align: center;

    }

 .ze1,.ze2,.ze3,.ze4,.ze5{

        display: inline-block;

        width: 90px;

        height: 100%;

        position: relative;

    }

Nach dem Login kopieren

(3) Pseudoelemente vor und nach

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

  .ze1:before,.ze2:before,.ze3:before,.ze4:before,.ze5:before{

        content:attr(data);

        position: absolute;

        color: #ffffff;

        top:0;

        left: 2px;

        transform-origin: left;

        transition: transform .5s;

    }

    .ze1:before{

        content: "前";

    }

    .ze2:before{

        content: "端";

    }

    .ze3:before{

        content: "小";

    }

    .ze4:before{

        content: "学";

    }

    .ze5:before{

        content: "生";

    }

    .ze1:after,.ze2:after,.ze3:after,.ze4:after,.ze5:after {

        position: absolute;

        color: #b3b3b3;

        top:3px;

        left: 10px;

        z-index: -1;

        transform-origin: left;

        transition: transform .5s;

    }

    .ze1:after{

        content: "前";

    }

    .ze2:after{

        content: "端";

    }

    .ze3:after{

        content: "小";

    }

    .ze4:after{

        content: "学";

    }

    .ze5:after{

        content: "生";

    }

Nach dem Login kopieren

(4) Animation dafür festlegen

1

2

3

4

5

6

.ze1:hover:before,.ze2:hover:before,.ze3:hover:before,.ze4:hover:before,.ze5:hover:before{

        transform: rotateY(-40deg) skewY(10deg);

    }

    .ze1:hover:after,.ze2:hover:after,.ze3:hover:after,.ze4:hover:after,.ze5:hover:after{

        transform: rotateY(40deg) skewY(10deg);

    }

Nach dem Login kopieren

1.1.2 Quellcode:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

nbsp;html>

 

 

    <meta>

    <title>动态字</title>

    <style>

        #box{

            margin: 100px auto;

            font-size: 100px;

            color:#005aa0;

            text-align: center;

        }

        .ze1,.ze2,.ze3,.ze4,.ze5{

            display: inline-block;

            width: 90px;

            height: 100%;

            position: relative;

        }

        .ze1:before,.ze2:before,.ze3:before,.ze4:before,.ze5:before{

            content:attr(data);

            position: absolute;

            color: #ffffff;

            top:0;

            left: 2px;

            transform-origin: left;

            transition: transform .5s;

        }

        .ze1:before{

            content: "前";

        }

        .ze2:before{

            content: "端";

        }

        .ze3:before{

            content: "小";

        }

        .ze4:before{

            content: "学";

        }

        .ze5:before{

            content: "生";

        }

        .ze1:after,.ze2:after,.ze3:after,.ze4:after,.ze5:after {

            position: absolute;

            color: #b3b3b3;

            top:3px;

            left: 10px;

            z-index: -1;

            transform-origin: left;

            transition: transform .5s;

        }

        .ze1:after{

            content: "前";

        }

        .ze2:after{

            content: "端";

        }

        .ze3:after{

            content: "小";

        }

        .ze4:after{

            content: "学";

        }

        .ze5:after{

            content: "生";

        }

        .ze1:hover:before,.ze2:hover:before,.ze3:hover:before,.ze4:hover:before,.ze5:hover:before{

            transform: rotateY(-40deg) skewY(10deg);

        }

        .ze1:hover:after,.ze2:hover:after,.ze3:hover:after,.ze4:hover:after,.ze5:hover:after{

            transform: rotateY(40deg) skewY(10deg);

        }

    </style>

 

 

    <p>

        </p><p>前</p>

        <p>端</p>

        <p>小</p>

        <p>学</p>

        <p>生</p>

     

Nach dem Login kopieren

1.1.3 Keine Ideen schreiben, nur Quellcode

1.1.3 Quellcode:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

186

187

188

189

190

191

192

193

194

195

196

197

198

199

200

201

202

203

204

205

206

207

208

209

210

211

212

213

  nbsp;html>

 

 

    <meta>

    <meta>

    <meta>

    <title>3d动画</title>

    

    <style>

    body{

    margin: 0;  

    background:url(iom.jpg) ;

    background-size:100%;

    position: relative;

}

 

.box{

    width:430px;

    height: 430px;

    position: absolute;;

    top:100px;

    left: 480px;

    border: 1px solid #ccc;

    border-radius: 215px;

    text-align: center;

    animation: dong 20s infinite linear;

    

}

 

.ai{

    width:10px;

    height: 10px;

    background: #0c0;

    border-radius: 5px;

    position: absolute;

    right:38px;

    top: 340px;

}

 

@keyframes dong{

    0%{

        transform:rotate(0deg)

    }

 

    100%{

        transform:rotate(720deg)

    }

}

 

 

.mrin{

    width:320px;

    height: 320px;

    border:1px solid #ccc;

    border-radius: 180px;

    position: absolute;

    top:155px;

    left: 535px;

    animation: mi 15s infinite linear;

}

 

.ak{

    width:50px;

    height: 50px;

    border: 1px solid #ccc;

    margin: 20px 0 0 20px;

    border-radius: 25px;

    display: inline-block;

    animation: ol 5s infinite linear;

}

 

.ak .sj1{

    width:10px;

    height:10px;

    border-radius: 5px;

    margin:20px 0 0 20px;

    background: blue;

}

 

.ak .sj2{

    width: 10px;

    height: 10px;

    margin-top:5px;

    background: #fff;

    border-radius: 5px;

}

 

 

@keyframes mi{

    0%{

        transform:rotate(0deg)

    }

 

    100%{

        transform:rotate(720deg)

    }

}

 

 

 

@keyframes ol{

    0%{

        transform:rotate(0deg)

    }

 

    100%{

        transform:rotate(720deg)

    }

}

 

 

.mian{

    width: 240px;

    height: 240px;

    border:1px solid #ccc;

    position: absolute;

    border-radius: 120px;

    top:195px;

    left:575px;

    animation: af 5s infinite linear;

}

 

 

.mian .ap{

    width: 10px;

    height: 10px;

    border-radius: 5px;

    background: #f0f;

    margin:30px 0 0 30px;

 

}

 

 

@keyframes af{

    0%{

        transform:rotate(0deg)

    }

 

    100%{

        transform:rotate(720deg)

    }

}

 

 

.chen{

    width: 160px;

    height: 160px;

    border: 1px solid #ccc;

    position: absolute;

    border-radius: 80px;

    top:235px;

    left:615px;

    animation: oa 4s infinite linear;

}

 

 

.ze{

    width: 10px;

    height: 10px;

    border-radius: 5px;

    background: #0c0;

    margin: 20px 0 0 15px;

}

 

 

@keyframes oa{

    0%{

        transform:rotate(0deg)

    }

 

    100%{

        transform:rotate(720deg)

    }

}

 

.yu{

    width: 80px;

    height: 80px;

    background-color:darkorange;

    border-radius: 40px;

    position: absolute;

    top:275px;

    left:655px;

    opacity: .7;

}

     

    </style>

 

 

    <p>

         

        </p><p></p>

     

        <p>

            </p><p>

                </p><p></p>

                <p></p>

               

                

             

         

            <p>

                </p><p></p>

             

                <p>

                    </p><p></p>

                     

                        <p></p>

                    

                 

          

       

     

Nach dem Login kopieren


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

.ak .sj2{

    width: 10px;

    height: 10px;

    margin-top:5px;

    background: #fff;

    border-radius: 5px;

}

 

 

@keyframes mi{

    0%{

        transform:rotate(0deg)

    }

 

    100%{

        transform:rotate(720deg)

    }

}

 

 

 

@keyframes ol{

    0%{

        transform:rotate(0deg)

    }

 

    100%{

        transform:rotate(720deg)

    }

}

 

 

.mian{

    width: 240px;

    height: 240px;

    border:1px solid #ccc;

    position: absolute;

    border-radius: 120px;

    top:195px;

    left:575px;

    animation: af 5s infinite linear;

}

 

 

.mian .ap{

    width: 10px;

    height: 10px;

    border-radius: 5px;

    background: #f0f;

    margin:30px 0 0 30px; 

 

}

 

 

@keyframes af{

    0%{

        transform:rotate(0deg)

    }

 

    100%{

        transform:rotate(720deg)

    }

}

 

 

.chen{

    width: 160px;

    height: 160px;

    border: 1px solid #ccc;

    position: absolute;

    border-radius: 80px;

    top:235px;

    left:615px;

    animation: oa 4s infinite linear;

}

 

 

.ze{

    width: 10px;

    height: 10px;

    border-radius: 5px;

    background: #0c0;

    margin: 20px 0 0 15px;

}

 

 

@keyframes oa{

    0%{

        transform:rotate(0deg)

    }

 

    100%{

        transform:rotate(720deg)

    }

}

 

.yu{

    width: 80px;

    height: 80px;

    background-color:darkorange;

    border-radius: 40px;

    position: absolute;

    top:275px;

    left:655px;

    opacity: .7;

}

     

     

 

 

    <p>

         

        </p><p></p>

     

        <p>

            </p><p>

                </p><p></p>

                <p></p>

               

                

             

         

            <p>

                </p><p></p>

             

                <p>

                    </p><p></p>

                     

                        <p></p>

                    

                 

          

       

     

Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonCodebeispiele für die Implementierung von Spezialeffekten für 3D-Animationen mithilfe von CSS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage