效果预览

按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。

https://codepen.io/comehope/pen/YjYgey

可交互视频

此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。

请用 chrome, safari, edge 打开观看。

https://scrimba.com/p/pEgDAM/cpQpGtQ

源代码下载

每日前端实战系列的全部源代码请从 github 下载:

https://github.com/comehope/front-end-daily-challenges

代码解读

定义 dom,容器中包含 2 个元素,分别代表镜头和照片:

<div class="camera">
<span class="lens"></span>
<span class="picture"></span>
</div>

居中显示:

body {
margin: 0;
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(to left bottom, linen, tan);
}

画出相机的轮廓:

.camera {
width: 20em;
height: 23em;
font-size: 10px;
background:
linear-gradient(
blanchedalmond, blanchedalmond 10em,
wheat 10em, wheat 14em,
tan 14em
);
border-radius: 2em;
}

画出镜头的轮廓:

.camera {
position: relative;
} .lens {
position: absolute;
width: 8em;
height: 8em;
background:
radial-gradient(
cadetblue 2em,
#555 2em, #555 2.5em,
#333 2.5em, #333 4em
);
border-radius: 50%;
top: 3em;
left: 6em;
}

用线性渐变画出下方照片的出口:

.camera {
background:
linear-gradient(
transparent 18em,
#333 18em, #333 19.5em,
transparent 19.5em
) no-repeat center / 80% 100%,
linear-gradient(
blanchedalmond, blanchedalmond 10em,
wheat 10em, wheat 14em,
tan 14em
);
border-radius: 2em;
position: relative;
}

接下来修饰细节。
用伪元素画出相机的取景器和闪光灯:

.camera::before {
content: '';
position: absolute;
width: 4.5em;
height: 2em;
background-color: #333;
border-radius: 0.5em;
top: 1.5em;
left: 1.5em;
} .camera::after {
content: '';
position: absolute;
width: 3em;
height: 3em;
background-color: #333;
background-image: radial-gradient(
teal 10%,
#333 30%,
transparent 40%
);
right: 1.5em;
top: 1.5em;
border-radius: 0.3em;
}

用径向渐变画出相机上的按钮:

.camera {
background:
radial-gradient(
circle at 17em 7em,
black 0.8em,
darkgray 0.8em, darkgray 1em,
transparent 1em
),
radial-gradient(
circle at 3.6em 7em,
tomato 1em,
darkgray 1em, darkgray 1.2em,
transparent 1.2em
),
linear-gradient(
transparent 18em,
#333 18em, #333 19.5em,
transparent 18em
) no-repeat center / 80% 100%,
linear-gradient(
blanchedalmond, blanchedalmond 10em,
wheat 10em, wheat 14em,
tan 14em
);
}

用径向渐变画出镜头上的光影:

.lens {
background:
radial-gradient(
circle at 60% 45%,
khaki 0.1em,
transparent 0.3em
),
radial-gradient(
circle at 50% 40%,
khaki 0.3em,
transparent 0.5em
),
radial-gradient(
cadetblue 2em,
#555 2em, #555 2.5em,
#333 2.5em, #333 4em
);
}

接下来制作动画效果。
用伪元素模拟快门:

.lens::before,
.lens::after {
content: '';
position: absolute;
width: 5em;
height: 0.1em;
background-color: #333;
} .lens::before {
top: 1em;
} .lens::after {
bottom: 1em;
}

增加快门开合动画效果:

.lens::before,
.lens::after {
animation: take-a-photo 3s infinite;
} @keyframes take-a-photo {
10% {
height: calc(50% - 1em);
} 20% {
height: 0.1em;
}
}

画出照片:

.picture {
position: absolute;
width: inherit;
height: 13em;
top: 18em;
} .picture::before {
content: '';
position: absolute;
box-sizing: border-box;
width: 15em;
height: 15em;
background: #555;
left: 2.5em;
border: solid linen;
border-width: 0 1em 2em 1em;
bottom: 0;
}

增加打印照片的动画效果:

.picture {
height: 0em;
overflow: hidden;
animation: print 3s infinite;
} @keyframes print {
30% {
height: 0em;
} 80%, 100% {
height: 13em;
}
}

最后,把相机向上挪一点,保持垂直居中:

.camera {
transform: translateY(-3em);
}

大功告成!

原文地址:https://segmentfault.com/a/1190000015828039

如何用纯 CSS 创作一台拍立得照相机的更多相关文章

  1. 前端每日实战:94# 视频演示如何用纯 CSS 创作一台拍立得照相机

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/YjYgey 可交互视频 此视频是可 ...

  2. 前端每日实战:63# 视频演示如何用纯 CSS 创作一台烤面包机

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/OEBJRN 可交互视频 此视频是可 ...

  3. 前端每日实战:66# 视频演示如何用纯 CSS 创作一台咖啡机

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/rKPLMW 可交互视频 此视频是可 ...

  4. 前端每日实战:74# 视频演示如何用纯 CSS 创作一台 MacBook Pro

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/MXNNyR 可交互视频 此视频是可 ...

  5. 74.纯 CSS 创作一台 MacBook Pro

    原文地址:https://segmentfault.com/a/1190000015568609 HTML code: <div class="macbook"> &l ...

  6. 如何用纯 CSS 创作文本滑动特效的 UI 界面

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/QrxxaW 可交互视频教 ...

  7. 如何用纯 CSS 创作一种有削铁如泥感觉的菜单导航特效

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/XqYroe 可交互视频教 ...

  8. 如何用纯 CSS 创作 404 文字变形为 NON 文字的交互特效

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/ZoxjXm 可交互视频教 ...

  9. 如何用纯 CSS 创作炫酷的同心矩形旋转动画

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/bMvbRp 可交互视频教 ...

随机推荐

  1. 基于角色权限管理:rbac设计分析以及具体细节

    权限管理---设计分析以及具体细节 说起权限我们大家都知道,不一样的角色会有不一样的权限. 比如就像学生管理系统一样,管理员,老师,学生之间的权限都是不一样的,那么展示的页面也是不一样的. 所以,我们 ...

  2. uoj46玄学

    复杂度辣鸡没人权 疯狂爆oj 感觉要被众多uoj用户骂了 #include <bits/stdc++.h> #define ll long long #define LS ls[now]? ...

  3. Jmeter4.0----录制脚本(4)

    1.前言 Jmeter录制脚本有两种方式.1.通过第三方工具录制比如:Badboy,然后转化为jmeter可用的脚本:2.使用jmeter本身自带的录制脚本功能. 对于测试小白来说可用先使用jmete ...

  4. postgresql修改数据库名

    alter database abc rename to cba;

  5. spark 图文详解:资源调度和任务调度

    讲说spark的资源调度和任务调度,基本的spark术语,这里不再多说,懂的人都懂了... 按照数字顺序阅读,逐渐深入理解:以下所有截图均为个人上传,不知道为什么总是显示别人的QQ,好尴尬,无所谓啦, ...

  6. 重写FileUpload控件让它可以显示上传后的文件名

    我在以前的开发中经常遇到这样的场景:文件上传之后需要显示文件名,但是asp.net自带的fileupload是不能付给上传后的文件名值的. 以前都是做一个label显示的,今天想起来了,写个控件封装一 ...

  7. marquee标签(跑马灯)

  8. 《移动Web前端高效开发实战》笔记4--打造单页应用SPA

    路由是一个单页应用的核心,大部分前端框架都实现了一个复杂的路由库,包括动态路由,路由钩子,组件生命周期甚至服务器端渲染等复杂的功能.但是对于前端开发者而言,路由组件的核心是URL路径到函数的映射,了解 ...

  9. iOS优化

    load妙用 aop面向切面编程 NSNumber Or Int @()适配64位 经过漫长时间的学习 你终于掌握了iOS大法 你找到了份iOS开发的工作 信誓旦旦的要开始你的coding生涯 老板对 ...

  10. selenium +python之Page Obiect设计模式

    PageObject是selenium自动化测试项目开发实践的最佳设计模式之一,它主要体现对界面交互细节的封装,这样可以使测试案例更关注于业务而非界面细节,从而提高测试案例的可读性. 1.认识Page ...