Any idea on how to create something like this with pure css3?
Create a pure css3 progress bar
212 views Asked by it_Concepto At
3
There are 3 answers
0
On
How about something like this ?
.container{
width:500px;
height:100px;
overflow:hidden;
}
.secondary{
width:500px;
height:100px;
transform:rotate(-5deg);
transform-origin:100% 100%;
overflow:hidden;
}
.prgbr{
width:50px;
height:100px;
transform:rotate(5deg);
display:inline-block;
margin-top:-5px;
}
.prgbr:nth-child(1){
background:red;
}
.prgbr:nth-child(2){
background:red;
}
.prgbr:nth-child(3){
background:orange;
}
.prgbr:nth-child(4){
background:orange;
}
.prgbr:nth-child(5){
background:yellow;
}
.prgbr:nth-child(6){
background:lightgreen;
}
.prgbr:nth-child(7){
background:green;
}
<div class="container">
<div class="secondary">
<div class="prgbr"></div>
<div class="prgbr"></div>
<div class="prgbr"></div>
<div class="prgbr"></div>
<div class="prgbr"></div>
<div class="prgbr"></div>
<div class="prgbr"></div>
</div>
</div>
0
On
Whilst this may need a little bit of tinkering, you may be able to use something like:
$('#add').click(function() {
var x = parseInt($('.ran').val()) + 1;
$('.ran').attr('value', x);
});
$('#min').click(function() {
var x = parseInt($('.ran').val()) - 1;
$('.ran').attr('value', x);
});
html,body{margin:0;padding:0;background:#222; text-align:center;}
.onetoTen {
height: 100px;
width: 300px;
overflow: hidden;
position: relative;
background:lightgray;
padding:10px;
padding-bottom:0;
border-radius:10px;
border:5px solid dimgray;
margin: 20px auto;
}
.onetoTen div {
display: inline-block;
width: 9%;
height: 100%;
transform: skewY(-20deg);
transform-origin: bottom right;
vertical-align: bottom;
position: absolute;
bottom: 0;
}
.ran {
display: none;
}
.ran[value="0"] + .onetoTen div {
display: none;
}
.ran[value="1"] + .onetoTen div:nth-child(1) ~ div {
display: none;
}
.ran[value="2"] + .onetoTen div:nth-child(2) ~ div {
display: none;
}
.ran[value="3"] + .onetoTen div:nth-child(3) ~ div {
display: none;
}
.ran[value="4"] + .onetoTen div:nth-child(4) ~ div {
display: none;
}
.ran[value="5"] + .onetoTen div:nth-child(5) ~ div {
display: none;
}
.ran[value="6"] + .onetoTen div:nth-child(6) ~ div {
display: none;
}
.ran[value="7"] + .onetoTen div:nth-child(7) ~ div {
display: none;
}
.ran[value="8"] + .onetoTen div:nth-child(8) ~ div {
display: none;
}
.ran[value="9"] + .onetoTen div:nth-child(9) ~ div {
display: none;
}
.ran[value="10"] + .onetoTen div:nth-child(10) ~ div {
display: none;
}
.onetoTen div:nth-child(1) {
left: 0;
height: 10%;
background: rgb(255, 0, 0)
}
.onetoTen div:nth-child(2) {
left: 10%;
height: 20%;
background: rgb(235, 0, 25)
}
.onetoTen div:nth-child(3) {
left: 20%;
height: 30%;
background: rgb(215, 0, 45)
}
.onetoTen div:nth-child(4) {
left: 30%;
height: 40%;
background: rgb(195, 0, 65)
}
.onetoTen div:nth-child(5) {
left: 40%;
height: 50%;
background: rgb(175, 0, 85)
}
.onetoTen div:nth-child(6) {
left: 50%;
height: 60%;
background: rgb(155, 0, 115)
}
.onetoTen div:nth-child(7) {
left: 60%;
height: 70%;
background: rgb(125, 0, 135)
}
.onetoTen div:nth-child(8) {
left: 70%;
height: 80%;
background: rgb(105, 0, 155)
}
.onetoTen div:nth-child(9) {
left: 80%;
height: 90%;
background: rgb(85, 0, 175)
}
.onetoTen div:nth-child(10) {
left: 90%;
height: 100%;
background: rgb(0, 0, 255)
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input class="ran" value="1" type="progress" min="0" max="10" />
<div class="onetoTen">
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
</div>
<button id="add">Add</button>
<button id="min">minus</button>
Please note the JQuery included in my answer I'm sure can be improved, and so is only included for demo purposes (as it would require validation rules to be included)
CSS
You can do this with css alone.
Just using <div> tags and setting color and position to create the shape.