gpt4 book ai didi

javascript - CSS 和 JS 饼图

转载 作者:行者123 更新时间:2023-11-28 06:24:16 25 4
gpt4 key购买 nike

得益于主要 CSS 属性 rotate:xdegborder-radius:100%overflow,我制作了一个 pieChart 函数:隐藏。这帮助我制作了任意大小的旋转四分之一馅饼。

这是代码:

function getRandomColor() {
var letters = '0123456789ABCDEF'.split('');
var color = '#';
for (var i = 0; i < 6; i++) {
color += letters[Math.floor(Math.random() * 16)];
}
return color;
} //http://stackoverflow.com/questions/1484506/random-color-generator-in-javascript

function drawQuarter(percent, angle, color) {
var widthPercent = 90 - percent;
var widthAngle = angle - 90 + percent;
var output = '<div class="frame_0" style="transform: rotate(' + widthAngle + 'deg);">';
output += '<div class="frame_1">';
output += '<div class="frame_2" style="transform: rotate(' + widthPercent + 'deg);">';
output += '<div class="square" style="background-color:' + color + '">';
output += '</div>';
output += '</div>';
output += '</div>';
output += '</div>';

return output;
}

function pieChart(valuesArray) {
var percent = [];
var quarterQuantityArray = [];
var HTMLoutput, dtop, dleft;
var startAngle = 90;
var rotation = startAngle;
var output = '';
var piechartSize = 40; // Half width of the piechart defined in css
var pi = Math.PI;

var sum = valuesArray.reduce(function(pv, cv) {
return parseInt(pv) + parseInt(cv);
}, 0); //http://stackoverflow.com/questions/3762589/fastest-javascript-summation

if (sum == 0) //Case no data
{
HTMLoutput = '<div class="frame_square nodata"></div>';
dtop = 30;
dleft = 16;
HTMLoutput += '<div class="label" style="top:' + dtop + 'px; left:' + dleft + 'px; line-height:normal;width:50px;">No data</div>';
return HTMLoutput;
} else { //Case with data

for (var i = 0; i < valuesArray.length; i++) {
percent[i] = valuesArray[i] / sum;
quarterQuantityArray[i] = Math.ceil(percent[i] * 4);
}

for (var m = 0; m < valuesArray.length; m++) {
var colorArray = ['#ef5350', '#66BB6A', '#26A69A'];
var color = m > 2 ? getRandomColor() : colorArray[m];
for (var j = 1; j <= quarterQuantityArray[m]; j++) {
if (j != quarterQuantityArray[m]) {
output += drawQuarter(90, rotation, color);
rotation += 90;
}
if (j == quarterQuantityArray[m]) {
var angle = percent[m] * 360 % 90;
angle = angle == 0 ? 90 : angle; //In case of 25%, 50%, 75% and 100%
output += drawQuarter(angle, rotation, color);
rotation += angle;
}
}
}

var HTMLoutput = output;

//Add labels
//Case 100% for one value
if (percent.indexOf(1) != -1) {
dtop = piechartSize - 5;
dleft = piechartSize - 10;
HTMLoutput += '<div class="label" style="top:' + dtop + 'px; left:' + dleft + 'px; line-height:normal;">100%</div>';
} else {
var labelFrameSize = 10; //Half .piechart .label css size
var label_int = piechartSize * 1 / 3; //retrait vers l'interieur du disque
var rotation = (startAngle + 180) / 180;
for (var n = 0; n < valuesArray.length; n++) {
var deg = (rotation + percent[n]) * pi ;
var labelY = piechartSize * (1 + Math.sin(deg)) - labelFrameSize - label_int * Math.sin(deg);
var labelX = piechartSize * (1 + Math.cos(deg)) - labelFrameSize - label_int * Math.cos(deg);
HTMLoutput += '<div class="label" style="top:' + labelY + 'px; left:' + labelX + 'px;">' + Math.round(percent[n] * 100, 0) + '%</div>';
rotation += 2 * percent[n];
}
}
return HTMLoutput;
}
}

var test = pieChart(['6', '5', '4','8']);
document.getElementById('test').innerHTML = test;;
div.piechart,
.piechart .frame_0,
.piechart .frame_2 {
width: 80px;
height: 80px;
}

.piechart .frame_1,
.piechart .square {
width: 40px;
height: 40px;
}

div.piechart {
position: relative;
float: left;
margin-right: 10px;
text-align: center;
}

.piechart .frame_0 {
position: absolute;
}

.piechart .frame_1 {
overflow: hidden;
}

.piechart .square {
border-radius: 100% 0 0 0;
}

.piechart .nodata {
border-radius: 100%;
background-color: #FFD419;
}

.piechart .label {
position: absolute;
text-align: center;
width: 20PX;
height: 20PX;
line-height: 20PX;
font-size: 7pt;
color: white;
font-weight: bold;
}
<div id="test" class="piechart">

</div>

问题是四分之一和内部四分之一之间有大于 25% 的白线,我想将其删除,但我不知道如何删除,有人有想法吗?

JSfiddle

最佳答案

我找到了解决这个问题的技巧:我在 .square div 上添加了 0.01em 的边框底部。此处更新了代码(自第一个版本以来已进行了优化):

function getRandomColor() {
var letters = '0123456789ABCDEF'.split('');
var color = '#';
for (var i = 0; i < 6; i++) {
color += letters[Math.floor(Math.random() * 16)];
}
return color;
} //http://stackoverflow.com/questions/1484506/random-color-generator-in-javascript

function drawQuarter(percent, angle, color) {
var widthPercent = 90 - percent;
var widthAngle = angle - 90 + percent;
var output = '<div class="frame_0" style="transform: rotate(' + widthAngle + 'deg);"><div class="frame_1"><div class="frame_2" style="transform: rotate(' + widthPercent + 'deg);"><div class="square" style="background-color:' + color + '; border-bottom:' + color + ' 0.01em solid;"></div></div></div></div>';

return output;
}

function pieChart(valuesArray) {
var percent = [];
var quarterQuantityArray = [];
var HTMLoutput, dtop, dleft;
var startAngle = 90;
var rotation = startAngle;
var output = '';
var piechartSize = 100; // Half width of the piechart defined in css
var pi = Math.PI;

var sum = valuesArray.reduce(function(pv, cv) {
return parseInt(pv) + parseInt(cv);
}, 0); //http://stackoverflow.com/questions/3762589/fastest-javascript-summation

if (sum == 0) //Case no data
{
HTMLoutput = '<div class="frame_square nodata"></div>';
dtop = piechartSize - 5;
dwidth = 2*piechartSize;
HTMLoutput += '<div class="label" style="top:' + dtop + 'px; width:' + dwidth + 'px; line-height:normal;">No data</div>';
return HTMLoutput;
} else { //Case with data

for (var i = 0; i < valuesArray.length; i++) {
percent[i] = valuesArray[i] / sum;
quarterQuantityArray[i] = Math.ceil(percent[i] * 4);
}

for (var m = 0; m < valuesArray.length; m++) {
var colorArray = ['#ef5350', '#66BB6A', '#26A69A'];
var color = m > 2 ? getRandomColor() : colorArray[m];
for (var j = 1; j <= quarterQuantityArray[m]; j++) {
if (j != quarterQuantityArray[m]) {
output += drawQuarter(90, rotation, color);
rotation += 90;
} else {
var angle = percent[m] * 360 % 90;
angle = angle == 0 ? 90 : angle; //In case of 25%, 50%, 75% and 100%
output += drawQuarter(angle, rotation, color);
rotation += angle;
}
}
}

var HTMLoutput = output;

//Add labels
//Case 100% for one value
if (percent.indexOf(1) != -1) {
dtop = piechartSize - 5;
dleft = piechartSize - 10;
HTMLoutput += '<div class="label" style="top:' + dtop + 'px; left:' + dleft + 'px; line-height:normal;">100%</div>';
} else {
var labelFrameSize = 10; //Half .piechart .label css size
var label_int = piechartSize * 1 / 3; //retrait vers l'interieur du disque
var rotation = (startAngle + 180) / 180;
for (var n = 0; n < valuesArray.length; n++) {
var deg = (rotation + percent[n]) * pi ;
var labelY = piechartSize * (1 + Math.sin(deg)) - labelFrameSize - label_int * Math.sin(deg);
var labelX = piechartSize * (1 + Math.cos(deg)) - labelFrameSize - label_int * Math.cos(deg);
HTMLoutput += '<div class="label" style="top:' + labelY + 'px; left:' + labelX + 'px;">' + Math.round(percent[n] * 100, 0) + '%</div>';
rotation += 2 * percent[n];
}
}
return HTMLoutput;
}
}

document.getElementById('test0').innerHTML = pieChart(['6', '5', '5','1']);
document.getElementById('test1').innerHTML = pieChart(['0', '0', '0']);
div.piechart,
.piechart .frame_0,
.piechart .frame_2,
.piechart .nodata {
width: 200px;
height: 200px;
}

.piechart .frame_1,
.piechart .square {
width: 100px;
height: 100px;
}

div.piechart {
position: relative;
float: left;
margin-right: 10px;
text-align: center;
}

.piechart .frame_0 {
position: absolute;
}

.piechart .frame_1 {
overflow: hidden;
}

.piechart .square {
border-radius: 100% 0 0 0;
}

.piechart .nodata {
border-radius: 100%;
background-color: #FFD419;
}

.piechart .label {
position: absolute;
text-align: center;
width: 20PX;
height: 20PX;
line-height: 20PX;
font-size: 7pt;
color: white;
font-weight: bold;
}
<div id="test0" class="piechart"></div>
<div id="test1" class="piechart"></div>

我希望任何人都会发现这个免费的简单饼图很有用。但请确定它至少对我自己有用......

关于javascript - CSS 和 JS 饼图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35257913/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com