- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
这是我的代码。我正在尝试连接/绘制中心和不同节点之间的路径。现在我想为不同的路径制作不同颜色的 stroke
。我已经创建了一个颜色数组,对于哪个路径将是描边颜色。但是我不能用不同的颜色制作 stroke
。
var lineFunction = d3.svg.line()
.x(function(d) { return d.x;})
.y(function(d) { return d.y;})
.interpolate("linear");
var lineGraph = vis.append("g")
.append("path")
.attr("d", lineFunction(CenterList))
.attr("stroke", function(d, i) { return ColorArr[i]; } )
.attr("stroke-width", 5)
.attr("fill", "none")
.attr("id", "viz");
ColorArr=black, black, red, red, black, black, black, red, black, red;
最佳答案
要为不同的线段设置不同的样式,它们必须是单独的线元素,而不是一条路径的所有部分。
但是,将折线图绘制为一系列线条元素会使代码复杂化。对于每个点,您不仅需要知道该点的数据,还需要知道前一个或下一个点(线的起点或终点)的数据。
我写了一个(更复杂的)用这种方式制作折线图的例子 for a previous SO question ,所以我能够快速为您调整它。
这是 fiddle :http://fiddle.jshell.net/4xZwb/3/
对于那个例子,我使用了一个“each”调用来对所有计算进行分组:
var lines = svg.append("g").attr("class", "plot").selectAll("line");
//define a d3 selection consisting of <line> elements
//that are grouped within g.plot
lines = lines.data(data);
//tell the selection to make room for every point in the data array
lines.enter().append("line");
//add one <line> element for every data point
lines.each(function(d,i){
//for each line in the selection, this function will be called
//with d equal to the data point and i equal to the index
//and "this" equal to the <line> element
var value = d;
//y-value for current point
//(we're just using the raw number from the array,
//normally it would be something like d.y or d[1] )
//find next point
var next = i+1; //x-position (just using index #)
var nextValue = data[i+1]; //y-position
if (isNaN(nextValue)){
// there is no next value,
// so repeat this point as the end of line
//(line will have zero length, but the marker will show up)
next = i;
nextValue = value;
}
d3.select(this) //select this particular <line> element
//so that we can use d3 methods
//set coordinates:
.attr(
{x1: xScale(i),
y1: yScale(value),
x2: xScale(next),
y2: yScale(nextValue)}
)
//Set styles for this individual line segment
//e.g., based on whether value is increasing
//or decreasing, we can set stroke colour red or black
.style("stroke", ( (value > nextValue) ?
"red" :
"black" )
);
});//end of "each" call
但是,您也可以单独设置它们,就像在这个版本中:
lines = lines.data(data);
lines.enter().append("line");
lines.attr("x1", function(d,i){return xScale(i);})
.attr("x2", function(d,i){
return xScale( (i+1 == data.length)?i:i+1);
})
.attr("y1", function(d,i){return yScale(d);})
.attr("y2", function(d,i){
return yScale( (i+1 == data.length)?
d:data[i+1]);
})
.style("stroke", function(d,i){
return ( (d > data[i+1]) ?
"red" : "black" )
});
关于javascript - 在 D3.js 树的中心和不同节点之间绘制不同颜色的 "strokes",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21219557/
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: How to align a to the middle of the page 这是一个简单的问题,应该有一个简
我想知道如何在屏幕中央的ListView中生成2个itens。 class _CategoriesState extends State { List categories = ["Anterio
我需要修复 UICollectionView 的一个小问题,当在 6s 设备尺寸上时,我得到如下布局: 但是,我想知道将它们居中以使其成为两条线的最佳方法是什么,或者我应该将它们缩小一点以便可以放置其
我尝试在 UIImageView 中居中 CAShapeLayer 但没有成功,我找到了解决方案,将其(CAShapeLayer)添加到 UIVIew,然后将 UIVIew 添加到 ImageView
一直在从线性布局和相对布局切换,因为我想实现图像的居中。 显示图片:
* { margin:0; padding:0; } /** General Style Info **/ body { background: #003d4c; co
我目前正在尝试修改我在 Wordpress 上的 Royal Slider 插件 (http://dimsemenov.com/plugins/royal-slider/) 我的目标是将所有标题的文本
我已经坚持了一段时间,因此简化了我的要求。当您单击标记时,信息窗口将打开,当用户缩放时,我希望该标记位于 map 的中心。这不起作用,但我认为它很接近: function bindInfoWindow
/* Linked Styles */ body { padding: 0 !important;
这个问题在这里已经有了答案: How do I center floated elements? (12 个答案) 关闭 7 年前。
这个问题在这里已经有了答案: Is there an equivalent to background-size: cover and contain for image elements? (1
我试图让我的页眉停留在页面的中间,不管我在什么窗口大小。 我试过使用 Bootstrap。 StackOverflow 还有这个 CSS。 .section-t
我有一个 1600 像素宽的页面。主要区域虽然只有 900 像素宽。我有一个导航应该固定在页面的中心(它是)。我的问题是当我打开页面时,页面固定在左侧而不是在打开时居中。当用户访问该网站时,我需要做什
我正在尝试找到 View 的中心。对于非旋转 View ,该值是正确的,但对于旋转 View ,它不正确,因为中心 (0,0) 正在旋转。在缩放的情况下,即使缩放后宽度和高度也保持不变 我正在使用以下
预期效果是将 Kartennummer 和 Passwort 集中。 这怎么可能? 我为此使用了一个自定义类: import 'package:flutter/material.dart'; impo
我管理着许多 Maven 项目。他们中的大多数部署到我们的内部 maven 存储库。现在我想开始向 Maven Central 发布一个项目。到目前为止,我有一个父 POM,它指定了我们内部存储库的
我试图锚定两个进展,但我看不到获得预期结果的方法。 我希望左边的进度条固定在左边,右边的条固定在中心固定(如下图所示) (下图显示调整大小的表格) 我尝试将控件放在具有各种 anchor 的停靠面板上
我正在玩 Angular 模态 ui 对话框。我想知道有什么方法可以让它居中?我发现了一个类似的问题: Twitter Bootstrap - Center Modal Dialog 但无法使其工作,
是否可以将值标签放置在条形上,使它们位于条形的中心? 如果我设置条形 align: "center",则条形上的标签将关闭且不居中。 $(function() { var d
http://www.asp.net/signalr/overview/signalr-20/getting-started-with-signalr-20/tutorial-signalr-20-s
我是一名优秀的程序员,十分优秀!