我正在尝试创建一个自定义进度条,如下图所示:
我认为创建这种类型组件的最佳选择是使用JavaScript和SVG或Canvas,现在我试图在Raphael JS中创建它。
我想知道这是否可能,或者这是一件令人难以置信的艰难事情,或者拉斐尔不是最好的工具,我对拉斐尔来说是新手,而我所做的就是通过以下方式重新塑造形状使用Raphael JS。
window.onload = function() {
var paper = Raphael("holder", 500, 500);
var border = paper.path("M177.726,35.14c-6.51-19.56-24.73-30.02-46.369-35.14l-4.061,3.7c16.59,5.44,29.609,15.21,33.25,30.37c6.891,28.729-26.721,55.2-70.56,55.2c-43.84,0-77.45-26.471-70.55-55.2c3.64-15.16,16.65-24.93,33.24-30.37L48.616,0c-21.64,5.12-39.86,15.58-46.37,35.14c-12.83,38.52,31.03,74,87.74,74C146.696,109.14,190.556,73.66,177.726,35.14z M89.986,107.014c-33.546,0-64.678-13.115-79.311-33.411C2.173,61.81-0.044,48.742,4.263,35.812C9.725,19.401,24.444,8.14,48.018,2.332l0.595,0.542C31.43,9.313,20.658,19.875,17.369,33.574c-2.601,10.831,0.055,21.67,7.682,31.346c12.873,16.331,37.755,26.477,64.935,26.477c27.177,0,52.06-10.145,64.936-26.475c7.63-9.676,10.29-20.516,7.691-31.348c-3.289-13.696-14.065-24.26-31.253-30.701l0.594-0.542c23.574,5.809,38.293,17.069,43.754,33.48c4.307,12.93,2.09,25.998-6.412,37.791C154.663,93.898,123.532,107.014,89.986,107.014z");
var fill = paper.path("M173.587,33.481C168.126,17.069,153.407,5.809,129.833,0l-0.594,0.541c17.188,6.441,27.963,17.004,31.252,30.701c2.6,10.832-0.061,21.672-7.691,31.348c-12.875,16.33-37.758,26.475-64.936,26.475c-27.18,0-52.063-10.146-64.936-26.477c-7.627-9.676-10.283-20.516-7.682-31.346C18.536,17.543,29.309,6.981,46.491,0.542L45.896,0C22.322,5.809,7.603,17.069,2.142,33.48c-4.307,12.931-2.09,25.998,6.412,37.791c14.633,20.296,45.764,33.411,79.311,33.411s64.678-13.115,79.311-33.411C175.677,59.478,177.894,46.411,173.587,33.481z");
border.attr({
fill: "#00FFFF",
});
fill.attr({
fill: "#99FF00",
});
}
答案 0 :(得分:0)
最好使用KineticJS或任何其他API来使用Canvas,这样可以帮助您快速了解几何形状及其操作。由于您可以轻松使用颜色过渡以获得您想要查看的进度。如果你研究Canvas而不是SVG,这将是一个很好的方法。
答案 1 :(得分:0)
如果你可以把这个填充分成多个部分......说十件。
然后第一件将是10%必须在左边。 然后你可以用你想要的颜色填充那个..
然后你可以用你想要的任何颜色填充下一个。
然后你没有一个填充路径,而是有很多,你可以将这些路径放入一个数组中并迭代该数组并填充它们。
然后,如果你迭代到第三个元素并填充..你将填充整个进度条的前三十分之一。
然后当然你可以将它分成任意数量,你可以把它分为一百或其他任何东西。
然后用一个名为'fill_progress_bar({“up_to”:30})的函数将其包起来 然后例如将进度条填满30%。
您还可以创建一个函数'fill_bar_portion({'number'=> 3,'with_color':'red'})',然后例如用红色填充进度条的第十个十进制数。这样,您可以轻松地使用您想要的任何颜色组合填充进度条。并非它没有必要,但它显示了你现在对进度条的控制程度。
一旦设置好,你就基本完成了,再也不用担心了。
但请记住在编程时记下算法,因为现在可能看起来显而易见的事情可能在六个月内不那么明显。或者对其他开发者来说。