- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个在 svg Canvas 上绘制折线图的代码,但我正在努力更改使用 d3.scaleOrdinal 函数定义的颜色。
我定义了 12 种可区分的颜色,但得到的结果是 this 。谁能帮我?谢谢。
var color2 = d3.scaleOrdinal().range([
'#673ab7',
'#9c27b0',
'#e91e63',
'#f44336',
'#ff5722',
'#ff9800',
'#ffc107',
'#ffeb3b',
'#cddc39',
'#8bc34a',
'#4caf50',
'#009688'])
.domain(d3.range(1,13));
var line = d3.line()
.x(function(d) { return x(d.day); })
.y(function(d) { return y(d.temp); });
var lineChart = function(csvfile, i) {
d3.csv(csvfile, function(error, data){
data.forEach(function(d){
d.month = +d.month,
d.day= +d.day,
d.temp= +d.temp;
});
svg.append('path')
.data([data])
.attr('class','line')
.style('stroke', function(i){ return color2(i);})
.attr('d', line);
}); //end of read csv
}; //end of line chart
lineChart('/static/data/temp1.csv'1);
lineChart('/static/data/temp2.csv'2);
lineChart('/static/data/temp3.csv'3);
lineChart('/static/data/temp4.csv'4);
lineChart('/static/data/temp5.csv',5);
lineChart('/static/data/temp6.csv',5);
lineChart('/static/data/temp7.csv',6);
lineChart('/static/data/temp8.csv',7);
lineChart('/static/data/temp9.csv',8);
lineChart('/static/data/temp10.csv',80);
lineChart('/static/data/temp11.csv',90);
lineChart('/static/data/temp12.csv',100);
最佳答案
第一个问题:在 D3 中,第一个参数始终是数据,无论您将其命名为 d
、i
还是 p
。所以,这个:
.style('stroke', function(i){ return color2(i);})
应该是这样的:
.style('stroke', function(d, i){ return color2(i);})
但是由于第二个问题,这个改变不会起作用。
第二个问题:您为每一行调用lineChart
,每次调用它时索引将为0。
一个可能的解决方案是将索引作为参数传递:
lineChart('/static/data/temp1.csv', 1);
lineChart('/static/data/temp2.csv', 2);
lineChart('/static/data/temp3.csv', 3);
//...
并且,在函数中(我在这里猜测,因为您没有粘贴函数声明):
function lineChart(url, index){
//all your previous code
.style('stroke', function(){ return color2(index);})
.attr('d', line);
};
查看此演示:
var svg = d3.select("body").append("svg").attr("width", 500).attr("height", 200);
var color2 = d3.scaleOrdinal().range(['#673ab7','#9c27b0','#e91e63','#f44336','#ff5722','#ff9800','#ffc107','#ffeb3b','#cddc39','#8bc34a','#4caf50','#009688'])
.domain(d3.range(1,13));
function draw(dimention, index){
svg.append("rect").attr("x", Math.random()*470)
.attr("y", Math.random()*170).attr("width", dimention).attr("height", dimention)
.attr("fill", function(d,i){ console.log("index is " + i); return color2(index)});
}
draw(30, 1);draw(10, 2);draw(25, 3);draw(20, 4);draw(5, 5);
draw(10, 6);draw(8, 7);draw(12, 8);draw(10, 9);draw(17, 10);
<script src="https://d3js.org/d3.v4.min.js"></script>
关于javascript - D3v4 : indexing and selecting color set by scaleOrdinal,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40119301/
假设我有一个颜色数组(具有整个色谱,从红色到红色。)。较短的版本如下所示: public Color[] ColorArray = new Color[360] { Color.FromArgb(25
当我通过 http://jigsaw.w3.org/css-validator/validator?uri=http%3A%2F%2Fwww.gamefriction.com%2FCoded&prof
我需要帮助来解决验证 CSS。在这里,我在 W3 验证中遇到了 20 个相同的错误。我不明白。如果您能解决此问题,我将不胜感激。 错误:两种上下文中 color 和 background-color
我正在尝试覆盖 bootstrap4 样式。 我没有使用 Sass 的经验,但这看起来像是 bootstrap SCSS 文件中的错误。 我的自定义文件是: /* custom.scss */
我是 sass 的新手,我写了一些 sass 代码,但它没有编译。 $classes : primary secondary success warning danger; $colors
我想制作一个散点图,其中每个点都有一个球体。点及其球体都根据某些列值着色。 一个显示我想要的最小示例: library(ggplot2) library(vcd) # only needed for
我正在尝试添加一个选项来更改网站颜色。所以,我有一个工作正常的色域,但问题是当鼠标悬停时我需要将颜色更改为深 10%。函数 darken 表示第一个参数必须是颜色。 Error: argument `
我正在尝试从下拉菜单中更改主题颜色,但出现此错误:“预期类型为'List>'的值,但类型为之一 'MappedListIterable>' Color selected ; MaterialApp(
有没有办法将 Inno Setup 底部面板的背景颜色更改为白色? 谢谢你的帮助! 最佳答案 您描述的底部面板实际上是向导表单的区域,因此您只需设置 Color WizardForm 的属性(prop
sublime text包Color Highlighter看起来很有用。但是,它的行为似乎并不像文档中描述的那样。 根据文档: Usage : Just click or move the curs
我有一个由 Excel 2007 创建的文档: ... 在 xl/styles.xml 的字体定义中包含以下颜色: 我从ECMA标准了解到这个颜色索引指的是收藏于 xl/styles.xml如果有
简单问题: (如何)是否可以设置 的值在 Chrome 中选择此类输入时,要在颜色选择器中清空吗? 编辑:我想将输入的值更改为 "" 最佳答案 我认为它不能设置为透明,但您可以使用value="#c
我正在尝试截屏,检查屏幕截图中的某种颜色,如果找到该颜色,则单击它。 我遇到的问题是颜色的 RGB 值必须准确。 我想知道是否可以将图像转换为颜色很少的图像。 抱歉打扰了。我没有受过适当的训练。我现在
有谁知道为什么 CSS 为文本提供了 color,但没有 font-color 或 text-color? 看起来很反直觉,有点像text-decoration: underline 而不是font-
我想弄清楚为什么 mix-blend-mode: color; css 选择器和值会影响除白色以外的所有颜色,而不是影响除白色和黑色以外的所有颜色。有人可以向我解释为什么会这样吗? 最佳答案 来自 t
我正在尝试创建 Angular 2 主题,我按照网站上提到的教程进行操作。这是我的主题文件。 @import '~@angular/material/theming'; @include mat-co
我正在尝试更改 ProgressBar 中栏的颜色 pBar.setStyle("-fx-accent: green"); 但我遇到了一个问题:这似乎不适合我! (或者我只是不明白一些事情) 这是代码
给定最大迭代次数 = 1000 给我一些关于如何着色(红色、绿色、蓝色)的想法。我现在能想到的只有蹩脚的 2 种颜色渐变:( 真的有可能想出像这样美丽的东西吗? 最佳答案 该死的,他们不会让我一个新手
要将 url 参数解码为颜色,我使用此 HttpMessageConverter: public class ColorHttpMessageConverter implements HttpMess
我创建了一个显示色谱的自定义控件。我正在覆盖 OnRender() 方法以使用颜色绘制控件。由于某种原因,“计算”的颜色(R G B 值)具有一定的透明度,即使我将 Alpha 值 (A) 设置为最大
我是一名优秀的程序员,十分优秀!