如何将多站css3渐变转换为图像?

时间:2012-02-28 20:12:05

标签: css css3 gradient

我有一个用colorzilla创建的多重渐变,我已经成功地将其作为我网站的背景。它适用于firefox,chrome和IE9。对于IE7及以下版本,它只显示白色背景,这是可以接受但不可取的,坦率地说,回到2代,我并不担心。但是,IE8只显示从第一种颜色到最后一种颜色的渐变,在中间没有停止,这通常会摆脱中间颜色,在我的情况下是白色。为了使它更好一些,我改变它,所以白色将是该渐变的最后一种颜色,但它绝不是一个完美的建议。

对我而言,解决方案似乎是将我已创建的多段梯度从它所使用的css代码转换为一个我可以根据需要无休止地重复的图像,就像传统上在现代css渐变之前所做的那样。但是,我一直无法找到允许我在给定高度和宽度下执行此操作的任何工具或代码。有没有人知道任何能满足这些需求的工具,最好是免费的?出于这个问题的目的,我使用的梯度代码如下:

background: #72b4f9; /* Old browsers */

/* IE9 SVG, needs conditional override of 'filter' to 'none' */

background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/Pgo8c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjAlIiB5MT0iMCUiIHgyPSIwJSIgeTI9IjEwMCUiPgogICAgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzcyYjRmOSIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjI1JSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjQ1JSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9Ijk2JSIgc3RvcC1jb2xvcj0iIzU3YzE0ZiIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiMzOTc3MzEiIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGllbnQ+CiAgPHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEiIGhlaWdodD0iMSIgZmlsbD0idXJsKCNncmFkLXVjZ2ctZ2VuZXJhdGVkKSIgLz4KPC9zdmc+);

background: -moz-linear-gradient(top, #72b4f9 0%, #ffffff 25%, #ffffff 45%, #57c14f 96%, #397731 100%); /* FF3.6+ */

background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#72b4f9), color-stop(25%,#ffffff), color-stop(45%,#ffffff), color-stop(96%,#57c14f), color-stop(100%,#397731)); /* Chrome,Safari4+ */

background: -webkit-linear-gradient(top, #72b4f9 0%,#ffffff 25%,#ffffff 45%,#57c14f 96%,#397731 100%); /* Chrome10+,Safari5.1+ */

background: -o-linear-gradient(top, #72b4f9 0%,#ffffff 25%,#ffffff 45%,#57c14f 96%,#397731 100%); /* Opera 11.10+ */

background: -ms-linear-gradient(top, #72b4f9 0%,#ffffff 25%,#ffffff 45%,#57c14f 96%,#397731 100%); /* IE10+ */

background: linear-gradient(top, #72b4f9 0%,#ffffff 25%,#ffffff 45%,#57c14f 96%,#397731 100%); /* W3C */

filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#A2CEFB', endColorstr='#ffffff',GradientType=0 ); /* IE6-8 */

3 个答案:

答案 0 :(得分:2)

您可能想尝试CSS3Pie http://css3pie.com这是IE7 / IE8的快速/免费解决方案

或使用渐变背景制作器创建SVG图像 http://ie.microsoft.com/testdrive/graphics/svggradientbackgroundmaker/default.html

然后找到导入到photoshop的方法

答案 1 :(得分:0)

Photoshop总是适合我。我相信你可以使用GIMP。任何图像程序中的渐变对话框通常都具有与您使用的css生成器相同的滑块和属性。您应该打包以您想要的画布大小创建文件,然后基本上使用渐变工具的对话框来设置相同的设置。有关此问题的更多信息,请访问SuperUser或论坛上的用户。

我不知道将css转换为图片的应用程序。

答案 2 :(得分:0)

我最终在http://gradcolor.com/找到了一个基本上符合我要求的网站。我能够创建特定大小的多个渐变,并且网站创建了该文件供我下载并上传到网站。谢谢大家的建议,因为他们找到了我。