像这样的圆环进度图形,如果纯用 CSS 来实现,大家有什么好思路么?

2012-07-04 17:18:00 +08:00
 Livid
http://dribbble.com/shots/629733-App-UI-elements?list=following
9320 次点击
所在节点    CSS
27 条回复
zythum
2012-07-04 17:38:22 +08:00
这个。必须有个canvas.. 不然真没办法做出个扇形...
cutehalo
2012-07-04 17:41:27 +08:00
cutehalo
2012-07-04 17:46:36 +08:00
benzhe
2012-07-04 17:50:34 +08:00
http://nipponcolors.com 打开右侧的 On 后,左侧的颜色环在切换颜色的时候会有 CSS 动画
Mak
2012-07-04 17:57:48 +08:00
用 transform: matrix(......); 可以畫一個一角指向圓心的菱形,然後圓外面到部分用遮罩蓋起來就可以了。

麻煩的是遮罩層的邊框必須用圖片才能實現最外面哪個上黑下白漸變的「圓邊框」。
zythum
2012-07-04 18:01:49 +08:00
@benzhe 我懂了。用蒙板加旋转,还要做成左右两边的。等下有空做个demo
zythum
2012-07-04 18:05:25 +08:00
突然一想,貌似不用蒙板也能做。 吃完饭做个demo
zythum
2012-07-04 18:07:57 +08:00
@Mak 这个办法不好。只能做凸多边型,如果大于180度就不行了。
benzhe
2012-07-04 18:18:58 +08:00
@Mak 可以用 radial-gradient
yqrm
2012-07-04 18:27:53 +08:00
@cutehalo http://tutorialzine.com/ 这个站很不错,收藏了,感谢
zythum
2012-07-04 18:30:16 +08:00
radial-gradient 是做圆心向外这么个方向的渐变是做不错扇形的。
bitsmix
2012-07-04 18:47:51 +08:00
911
2012-07-04 19:00:42 +08:00
houkanshan
2012-07-04 19:23:51 +08:00
zythum
2012-07-04 19:43:50 +08:00
@houkanshan 和我实现实现的方式类似。但是用两个拼的话css transition怎么做过度呢。只能用js setTimeout或者祯动画做过度了
houkanshan
2012-07-04 19:49:25 +08:00
@zythum 嗯,原作者就是setTimeout过度的,实际上他的rotate都是setInterval控制的。。。
如果能用帧动画就更好了
benzhe
2012-07-04 19:54:53 +08:00
@zythum 抱歉误解了 @Mak 的意思,不过 border 的问题可以用 line-gradient 的 background 和 border-radius 解决。
我也尝试在做 DEMO, 不过卡住了,因为发现进度条首尾也有小渐变,看来不用图片不行了?
endintro
2012-07-04 20:02:48 +08:00
http://css-tricks.com/examples/ShapesOfCSS/ 里的Pac-Man + css3 transform rotate?
zythum
2012-07-04 20:08:04 +08:00
http://zythum.free.bg/circlerange/

纯css实现了,没图片,没用canvas。但是没做过度动画。等下整理下做个以后可以扩展的
zythum
2012-07-04 20:17:29 +08:00
@benzhe 可以不通图片的。你看下我写的demo就可以了。
@houkanshan 看看能不能做个大小可以自适应的样式

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/41396

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX