I am trying to develop a score bar where user can see his scores and also see the progress towards the top prize he could win.
The problem is in this bar there are 8 prizes and every prize has different prize points. You could win the small prize by collecting only 200 points, or you could win a trip by collecting 50000 points.
Now the problem is I have to show all the eight prize milestone on the bar and each one has the same difference space between all prize milestones
As you can see the picture user win 7800 points he achieve the milestone of 7500 now the main problem is I have to get the ratio of between these points to place the bottle on accurate place which I failed to do :( I tried so hard but nothig happend
You can see fiddle here: 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>
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);
It doesn't seem too difficult, but 7800 is a bad value to test with, because it's next to nothing from 7500 on a scale of 7500 to 15000. (So in the JSfiddle I changed it to 12700)
http://jsfiddle.net/Udwq9/9/
I modified to second for-loop to break once the milestones are larger than the user's score.
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;
}
}
Use following loop to count needed offset (looping from the end of the array):
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);
Here is the Demo
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With