- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将 d3.js 画笔和谷歌地图结合起来。我有一张 map 、3 个控制 d3 画笔的按钮(实际上是我的时间线)以及 d3 画笔本身。
按钮负责移动画笔,如果我不将 map 添加到页面,它们就会移动画笔。如果我将 map 添加到页面,则在启用 js 调试器(firebug 或 chrome 调试器)时,播放和停止功能将起作用。但是当我关闭调试器时,画笔不会重画。它的范围将被更新(我通过 alert(brush_control.extent()[0])
检查它),但它仍然保持在操作(播放或停止)之前的位置。
控制台没有异常或错误。
这是完成这项工作的脚本:
<script>
(function(){
var is_playing = false,
paddingLeft = 10,
paddingRight = 10,
paddingBottom = 5;
width = $(window).width() - $("#controls").width() - paddingLeft - paddingRight,
timeline_height = 100,
map_height = $(window).height() - timeline_height - paddingBottom,
my_data = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10],
brush_control = NaN;
$("#map").height(map_height);
// Remove the map below and everything works fine
var map = new google.maps.Map(d3.select("#map").node(), {
zoom: 8,
center: new google.maps.LatLng(-14.235004,-51.92528),
mapTypeId: google.maps.MapTypeId.ROADMAP
});
var timeline_svg = d3.select("#timeline").append("svg:svg")
.attr("class", "tl")
.attr("width", width)
.attr("height", timeline_height);
brush_control = d3.svg
.brush()
.x(d3.scale
.linear()
.domain([0, my_data.length])
.range([0, width])
)
.extent([0,1])
.on("brush", brush);
var brush_svg = timeline_svg.append("g")
.attr("class", "brush")
.call(brush_control)
.selectAll("rect")
.attr("height", timeline_height);
$("#playbtn")[0].addEventListener("click", play_event);
$("#pausebtn")[0].addEventListener("click", pause);
$("#stopbtn")[0].addEventListener("click", stop);
function play_event(){
if(is_playing != true){
is_playing = true;
play();
}
}
function play(){
var delay = 100;
setTimeout(function(){
var ex = brush_control.extent();
if(is_playing && ex[0 ] < my_data.length - 1){
d3.select("g").transition()
.duration(delay)
.call(brush_control.extent([ex[1], ex[1] + 1]));
ex = brush_control.extent();
play();
}
}, delay);
}
function pause(){
is_playing = false;
}
function stop(){
is_playing = false;
d3.select("g")
.transition()
.duration(1000)
.call(brush_control.extent([0, 1]))
.call(brush_control.event);
}
function brush() {
var s = d3.event.target.extent();
data_index = Math.floor(s[0]);
if (s[1]-s[0] != 1) {
d3.event.target.extent([s[0], s[0] + 1]);
d3.event.target(d3.select(this));
}
}
}());
</script>
最佳答案
问题是行 d3.select("g").transition()
没有选择您期望的内容,而是从谷歌地图插入的代码中选择的内容。如果你检查 DOM 元素,你会发现插入了一些 SVG 代码,例如:
<svg version="1.1" overflow="hidden" width="78px" height="78px" viewBox="0 0 78 78" style="position: absolute; left: 0px; top: 0px;">
<circle cx="39" cy="39" r="35" stroke-width="3" fill-opacity="0.2" fill="#f2f4f6" stroke="#f2f4f6"></circle>
<g transform="rotate(0 39 39)"><rect x="33" y="0" rx="4" ry="4" width="12" height="11" stroke="#a6a6a6" stroke-width="1" fill="#f2f4f6"></rect><polyline points="36.5,8.5 36.5,2.5 41.5,8.5 41.5,2.5" stroke-linejoin="bevel" stroke-width="1.5" fill="#f2f4f6" stroke="#000"></polyline>
</g>
</svg>
因此,将选择更改为
d3.select("g.brush").transition()
可以解决这个问题。
关于javascript - 为什么添加谷歌地图会使 d3.js 刷重绘在 Debug模式之外崩溃?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24551030/
Debug.Assert/Debug.Fail 是否自动条件编译#if "DEBUG"?或者它是否更像是没有附加调试器(即使在发行版中)它什么也做不了?如果是这样,将它们留在您的代码中是否会对性能产生
我有一个应用程序,我配置了多个路由,一切正常,直到我配置的最新路由不起作用(显示错误的屏幕)。 我的问题是如何进行调试?没有打印错误日志,我无法找到如何获取有关正在发生的事情的更多日志。我也不知道从哪
我正在 Intellij 中调试代码。我使用 maven 来构建项目,并且在本地 .m2 存储库中有该项目的各种版本。当我开始调试时,Intellij 继续从项目的前一个快照中选择旧版本的代码。如何让
我喜欢在业余时间进行一些 TiVo 黑客事件 - TiVo 使用 Linux 变体和 TCL 。我想在我的 Windows 笔记本电脑上编写 TCL 脚本,测试它们,然后将它们通过 FTP 传输到我的
我有 ASM 代码,它使用循环语法打印 abc 。这是我的代码 ;abc.com .model small .code org 100h start: mov ah, 02h mov
我在 Debugging .net 2.0 Applications 中看到了以下代码 [Conditional("DEBUG")] void AssertTableExists() { #i
在大型项目中哪个更好用,为什么: #if DEBUG public void SetPrivateValue(int value) { ... } #endif 或 [System.D
我似乎无法让调试器运行。调试运行图标变灰,菜单选项丢失。 这只是main的情况,我可以很好地调试单元测试。 类似的问题提到了项目结构,但我看不出有什么不对: $GOPATH/src/foo.bar.c
只是想知道我的浏览器一直询问我是否想在每次点击浏览器链接刷新时停止调试非常烦人,因为这会减慢开发时间。 有没有其他人遇到过这个? 干杯 最佳答案 更新的答案,现在找到根本原因 经过两年看到这个错误时断
我正在尝试包含调试/发布相关编译器标志,例如: set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=gnu++0x -Wall -DUSE_BOOST") set
当我尝试使用 debug.phonegap.com 调试我的phonegap 应用程序时遇到问题。 我把这个视频放在 HTML 文档的头部 在启动应用程序之前,我从 build.phonegap.
GDB 7.0以后,支持反向调试。 生成核心转储时,我可以使用反向调试命令吗? 我怎样才能做到这一点? 最佳答案 你不能。核心文件是某个时间点程序状态的快照。要在该状态下向后移动,您需要程序状态的较早
首先:如果之前有人问过这个问题,我很抱歉。我是一个熟练的谷歌用户,但这确实让我难住了,我找不到任何东西。 我目前正在编写一个小型库,我想对其进行调试。我还希望能够完全关闭调试,并且编译后的代码不应包含
我想在 tomcat 中将级别日志记录设置为 DEBUG,但在控制台中仍然只有 INFO 和 WARN 输出。谁能告诉我哪里出了问题? 我的 C:\tomcat\logging.properties:
我已经开始像这样使用定义类了: internal sealed class Defines { /// /// This constant is set to true iff th
在使用编译器指令时,我不清楚以下两个代码片段中哪一个是正确/首选的,以及为什么。似乎我见过的大多数开发人员和开源项目都使用第一种,但我也看到第二种也经常使用。 #ifdef DEBUG [self d
我遇到错误,无法完成构建。我搜索了 Stackoverflow 和 Github。我已经尝试了很多方法,但我无法修复。请帮忙。 (1) 在 [src/nullnull/debug, src/debug
我刚刚意识到,使用 TFS 部署时,DEBUG 处理器指令仍然有效,有没有办法更改 TFS/Azure 网站或构建定义中的设置,而不是在本地解决方案配置? 我仍然希望本地解决方案保持调试状态,只有部署
我有一段代码在 VS2008,C++ 中以 Debug模式运行。 问题是,当我逐行调试代码时,在代码的一个非常奇怪的地方,它崩溃并说: debug assertion faild. Expressio
我有一个简单的 Xamarin.Forms 项目,我在 Visual Studio 中运行,使用 iphone 模拟器。我在 App.cs 中有以下代码: protected override voi
我是一名优秀的程序员,十分优秀!