我正在努力开发一个分数栏,用户可以看到他的分数,并看到他可以赢得的最高奖项的进展.
问题在于这个酒吧有8个奖项,每个奖项都有不同的奖品.你可以通过只收集200分赢得小奖,或者你可以通过收集50000积分来赢得旅行.
现在的问题是我必须在酒吧上显示所有八个奖项里程碑,每个奖项里程碑之间的差异空间相同
正如你可以看到图片用户赢得7800分他达到7500的里程碑现在主要的问题是我必须得到这些点之间的比例将瓶放在准确的地方,我没有做到:(我努力但是nothig发生了
你可以在这里看到小提琴:http://jsfiddle.net/Udwq9/2/
HTML
<p> </p><p> </p><p> </p><p> </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>
脚本
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);
解决方法
它看起来并不太难,但7800是一个不值得测试的值,因为它在7500到15000的范围内从7500开始几乎没有.(所以在JSfiddle我将它改为12700)
一旦里程碑大于用户的分数,我修改为第二个for-loop中断.
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; } }