3

以下の画像のようなカスタム プログレス バーを作成しようとしています。

カスタム プログレス バー

このタイプのコンポーネントを作成するための最良のオプションは、JavaScript と SVG または Canvas を使用することだと思います。現在、これを 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",
});
}

JSフィドルシェイプ

4

2 に答える 2

0

その塗りつぶしを複数の部分に分割できる場合.. 10個と言います。

次に、最初のピースは左に 10% のマストになります。次に、それを塗りつぶすことができます..好きな色で。

次に、次のものを好きな色で塗りつぶすことができます。

次に、単一のフィルパスを持つ代わりに、多くのパスを持ち、それらのパスを配列に配置し、その配列を反復してそれらを埋めることができます。

次に、たとえば 3 番目の要素を反復して塗りつぶすと、進行状況バー全体の最初の 10 分の 3 が塗りつぶされます。

もちろん、それを任意の量に分割することもできます。

そして、'fill_progress_bar({"up_to":30})" という関数を作成して締めくくります。これにより、たとえば、進行状況バーが 30% 増加します。

関数 'fill_bar_portion({'number'=>3, 'with_color':'red'})' を作成することもできます。これは、たとえば、プログレス バーの 3 番目の 10 分の 1 を赤色で塗りつぶします。このようにして、プログレスバーを好きな色の組み合わせで塗りつぶすことも簡単になります. 必須ではないというわけではありませんが、これまでにプログレス バーをどの程度制御できるかを示しています。

セットアップが完了したら、基本的には完了です。これについて再度心配する必要はありません。

しかし、プログラムを作成するときは、アルゴリズムを書き留めておくことを忘れないでください。または、その点については他の開発者に。

于 2013-07-19T12:41:30.977 に答える