2014-01-17 8 views
7

私はユーザーが彼の得点を見ることができ、彼が勝つことができる最優秀賞に向かって進歩を見ることができるスコアバーを開発しようとしています。jqueryを使用して2つの配列の比率を取得

このバーには8つの賞があり、すべての賞にはさまざまな賞品ポイントがあります。 200ポイントしか集めることで小さな賞を獲得することも、50000ポイントを集めることで旅行に勝つこともできます。

は、今の問題は、私はバーの上のすべての8つの賞のマイルストーンを表示する必要があると絵のユーザーが7800に勝つあなたが見ることができるように各1は、すべての賞のマイルストーン

enter image description here

間で同じ差異スペースがあります彼は7500のマイルストーンを達成するポイント今私は私がしなかった正確な場所にボトルを置くためにこれらのポイントの間の比率を取得する必要があります:(私はとても難しいが、nothig happendを試してみた

あなたが見ることができますフィドル:http://jsfiddle.net/Udwq9/2/

HTML

<p>&nbsp;</p><p>&nbsp;</p><p>&nbsp;</p><p>&nbsp;</p> 

<div class="barCont"> 
     <div class="innerLight"></div> 
     <div class="innerDark"> </div> 
     <div class="seek"> 
     <div class="youRhere"> 
      <p>You are here:<br /> 
      <span id="Points">7800 Points</span></p> 
      <br /> 
     </div> 
     <img src="" width="17" height="74" alt=" " /> </div> 
     <div class="mileStone" style="">200 

     </div> 
     <div class="mileStone" style="">300 

     </div> 
     <div class="mileStone" style="">450 

     </div><div class="mileStone" style="">750 

     </div> 
     <div class="mileStone" style="">7500 

     </div> 
     <div class="mileStone" style="">15000 

     </div> 
     <div class="mileStone" style="">20000 

     </div><div class="mileStone" style="">50000 

     </div> 
    </div> 

SCRIPT

var TopScore = 50000; 
    var MileStone = new Array("200", "300", "450", "750", "7500", "15000", "20000", "50000"); 
    var barWidth = $('.innerLight').width(); 
    var ArrayLength = MileStone.length; 
    var milestonepos = barWidth/ArrayLength; 
    var milestoneposMain = milestonepos/ArrayLength; 
    var Points = $('#Points').text(); 
    var yourPoints = parseInt(Points); 
    var pos = 0; 
    var bottlePos = 0; 
    var posTwo = 0; 
    var posTwoMain = 0; 

    for(var i=0; i <= ArrayLength; i++){  
     var pos = pos + milestonepos; 
     $('.mileStone').eq(i).animate({ left: '' + pos + 'px' }); 
     //alert(pos)   
     } 
    var pos = 0; 
    for(var j=0; j<= ArrayLength; j++){ 
     if(yourPoints >= MileStone[j]) 
     { 

     var pos = pos + milestonepos; 

      /*var step1 = yourPoints - MileStone[j]; 
      var step2 = MileStone[j+1] - yourPoints; 
      var step3 = step2/step1; 
      var step4 = step3*100;*/ 
      // var pointsRatio = yourPoints - posRatio; 
      //var posTwoMain = parseFloat(posTwo.style.width) 
      //alert(parseInt(posRatio)); 
      //alert(parseInt(pointsRatio)); 
      // var pos = pos + pointsRatio; 
      } 

     } 
     $('.seek').animate({ left: '' + parseInt(pos) + 'px' }, 1000); 
+0

ですplzは申し訳ありませんが非でだから、再びスケールを – Kamal

+0

をチェックあなたは任意の2つのスコア値の間の直線的な位置の後にいますか?あれは正しいですか? –

+0

はい正しいです – Kamal

答えて

3

が、7800 7500から15000のスケールで7500から何もないので、テストする価値がありません。(JSfiddleでは12700に変更しました)

http://jsfiddle.net/Udwq9/9/

私はマイルストーンは、ユーザーのスコアより大きくなっている時点で2次forループ分割するように変更。

for(var j=0; j < ArrayLength; j++) 
{ 
    if(yourPoints >= MileStone[j]) 
    { 
     pos = pos + milestonepos; 
    } 
    else 
    { 
     prevMilestone = j ? MileStone[j-1] : 0; 
     pos += parseInt((yourPoints-prevMilestone)/(MileStone[j]-prevMilestone) * milestonepos); 
     break; 
    } 
} 
+0

ユーザーが50000ポイントを持っている場合にボトルが動かない – n1k1ch

+0

@ n1k1chこれをキャッチすることに感謝します。私はforループで '<='ではなく '<'を使用していたはずです。 – towr

0

だけ.barContためmargin-left: 8px;margin-left: -8px;を変更するには、それはここで を.seek:http://jsfiddle.net/Udwq9/3/

それはあまりにも難しいようではありません
+0

あなたの助けに感謝しますが、これは私の質問をもう一度読んでください.. – Kamal

1

使用相殺に必要なカウントするために、次のループ(配列の終わりからループ):ここで

var pos2 = 0; 

for(var j=ArrayLength-1; j >= 0; j--){ 
    var currentMilestone = parseInt(MileStone[j]); 

    //reaching "full" milestone 
    if(yourPoints >= currentMilestone) 
    { 
     pos2 = milestonepos * (j+1); 

     var diff = yourPoints - currentMilestone; 
     console.log("diff: " + diff); 

     //counting offset to move forward from "full" milestone 
     if(j < ArrayLength - 1) { 
      var nextMilestone = MileStone[j+1]; 
      var diffInPoints = nextMilestone - currentMilestone; 
      var subDiff = (milestonepos * diff)/diffInPoints; 
      pos2 += subDiff; 
     } 
     break; 
    } 
} 

console.log("pos2: " + pos2); 
$('.seek').animate({ left: '' + parseInt(pos2) + 'px' }, 1000); 

Demo

関連する問題