- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在使用 d3.js v4
。我目前正在实现程序化缩放。这Panning and Zooming Tutorial帮助很大。我的缩放适用于滚轮,但我想创建按钮来缩放。我知道缩放和平移所必需的是翻译 [tx, ty]
和比例因子 k
。我正在为我的 x 轴使用时间刻度。通过获取 p1(点 1)
和 p2 的像素值,我设法获得了
在 x 轴上,然后使用这些值获得 k(比例因子)。像这样:tx
和 k
的比例因子(点 2)
var k = 500 / (xScale(p2) - xScale(p1)); //500 is desired pixel diff. between p1 and p2, and xScale is my d3.scaleTime() accessor function.
// for this zoom i just want the first value and last value to be at scale difference of the entire width.
然后我通过这个计算 tx:
var tx = 0 - k * p1;
然后将其输入 d3.zoomIdentity()
并重新缩放我的 xdomain。我创建了一个按钮来缩小。问题是当我放大然后尝试使用按钮缩小时,它缩小了,但缩小了 x 轴。我似乎无法找出为什么它会缩小 x 轴而不是正确缩小。
我的 JSFiddle
https://jsfiddle.net/codekhalifah/Lmdfrho7/2/
我尝试过的
我的代码
应用滚轮缩放后我运行这个函数:
function zoomed() {
if (d3.event.sourceEvent && d3.event.sourceEvent.type === "brush") return; // ignore zoom-by-brush
var t = d3.event.transform;
console.log(t);
console.log(xScale.domain());
xScale.domain(t.rescaleX(x2).domain());
usageAreaPath.attr("d", area);
usageLinePath.attr('d',line);
weatherAreaPath.attr('d',weatherChart.area);
focus.select(".axis--x").call(xAxis);
focus.selectAll('.circle')
.attr('cx', function(d) { return xScale(getDate(d)); })
.attr('cy', function(d) { return yScale(d.kWh); })
.attr("transform", "translate(0," + 80 + ")");
... other non related items
}
缩放工作正常,但在放大然后手动尝试缩放回我想要的正常位置后。我的手动缩放按钮功能
function programmaticZoom(){
var currDataSet = usageLinePath.data()[0], //current data set
currDataSetLength = currDataSet.length,//current data set length
x1 = currDataSet[0].usageTime, //getting first data item
x2 = currDataSet[currDataSetLength-1].usageTime, //2nd data item
x1px = xScale(moment(x1)), //Get current point 1
x2px = xScale(moment(x2)); // Get current point 2
// calculate scale factor
var k = width / (x2px - x1px); // get scale factor
var tx = 0 - k * x1px; // get tx
var t = d3.zoomIdentity.translate(tx).scale(k); //create zoom identity
xScale.domain(t.rescaleX(window.x2).domain());
usageAreaPath.attr("d", area);
usageLinePath.attr('d',line);
weatherAreaPath.attr('d',weatherChart.area);
focus.select(".axis--x").call(xAxis);
focus.selectAll('.circle')
.attr('cx', function(d) { return xScale(getDate(d)); })
.attr('cy', function(d) { return yScale(d.kWh); })
.attr("transform", "translate(0," + 80 + ")");
}
最佳答案
我已经研究了一段时间了,我得到了它某种的工作,有一件事我无法弄清楚,但你也许可以,因为你看起来更比我熟悉d3。在你的programmaticZoom()
函数,我注意到 tx
是图形开始位置的偏移量,k
是规模。使用这个,我改变了 block :
var k = width / (x2px - x1px); // get scale
var tx = 0 - k * x1px; // get tx
var t = d3.zoomIdentity.translate(tx).scale(k);
到
var k = 1;
var t = d3.zoomIdentity.scale(k);
首先,当k = 1.0
,图形将完全适合窗口。我相信设置的原因k
它以前的值是错误的,当你增加k
的值时这样k > 1.0
,它将图形的宽度拉伸(stretch)到屏幕之外。必须重新调整图表上的内容,使其在图表上 占据尽可能多的空间,同时仍在屏幕范围内。与 k < 1
,这就是 width / (x2px - x1px);
发生的情况,图形缩小到小于屏幕大小。像这样重新调整只会使图表的内容适合在图表中可以占据的最大值,但是由于图表比屏幕小,它会被重新调整以适合缩小的图表并出现小于屏幕。
我摆脱了tx
完全是因为它偏移了图形的起始位置。当图表被放大时,它的宽度被拉伸(stretch)到屏幕之外。在此处进行偏移是有意义的,因为您需要使偏移量等于您想要开始查看图形的位置,并允许不需要的部分远离屏幕。在您一直缩小的情况下,图表是屏幕的大小,因此偏移将导致您的图表不会从屏幕的开头开始,而是插入一部分它离开屏幕。在您的情况下,使用 k
已经缩小了图形,偏移量导致缩小的图形出现在屏幕中间。但是,如果图形没有缩小,偏移量会将图形的一部分推离屏幕。
通过更改它,缩小按钮似乎 可以工作,但是仍然存在问题。在zoomed()
功能,你设置var t = d3.event.transform;
. d3.event.transform
包含 k, x, and y
的值需要是 1, 0, and 0
分别在完全缩小时。我无法更改 programmaticZoom()
中的这些值虽然功能,因为d3.event.transform
仅在触发事件后存在,特别是鼠标滚轮。如果您能够将这些值设为 k = 1, x = 0, y = 0
仅当单击缩放按钮时,问题才应完全解决。
希望这对某些人有所帮助,我对 d3 不是很熟悉,但这应该可以解决您的大部分问题,并希望让您了解出了什么问题。
关于javascript - 问题 w/Programmatic Zoom v4,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39625154/
我的问题分为两部分 1) 我想将文件名分配给 FileUpload 控件然后保存它,但问题是它是只读的 FileUpload1.FileName="ClientMachine\\Ima
我目前正在开发一个适用于 iOS 和 macOS 的跨平台应用程序,使您的 iOS 设备可以用作触控板。 使用CGDisplayMoveCursorToPoint,我可以在屏幕上移动光标。奇迹般有效。
要为其他应用程序提供 API,我们可以使用 android:exported="true" 导出我们自己的内容提供程序、服务和广播接收器在我们的应用程序中的 AndroidManifest.xml .
我正在构建一个同义词库应用程序,对于这个问题,关键是我正在为特定单词(例如 - “feline”、“tomcat”)添加同义词列表(具有相同含义的单词) "、"puss"是 "cat"的同义词) 我有
我正在创建音频,为它分配源并使用jquery以编程方式将其附加到页面,我还需要向该音频添加一个类,但是我无法使其工作,我尝试了以下操作: var song = new Audio(); song.sr
我想以编程方式使用 RadioButton 的属性 - android:button="@drawable/abc"。 我如何用 Java 编写这个? 最佳答案 试试这个 radioButton.se
什么是 QTP 中的描述性编程? 最佳答案 在不使用对象存储库的情况下创建测试称为描述性编程,因为您将对象描述为脚本的一部分。 例如 Browser("title:=Google").Page("ti
这个问题在这里已经有了答案: Android Activity, how to override manifest's android:configChanges with Java code? (2
我正在尝试将二进制数据存储在动态创建的 JCR 中。我的问题是 JCR API 提供的唯一方法是通过 InputStream : Session session = request.getResour
这个问题在这里已经有了答案: Set EditText Digits Programmatically (6 个回答) 2年前关闭。 我目前正在使用 android:digits="qwertzuio
我正在开发 Windows 窗体应用程序。我有以下问题:在一个表单中有一个面板,在那个面板中我有许多控件(只是一个带有文本框的标签,数量是在运行时确定的)。此面板的大小小于动态添加的所有控件的总和。所
在国际象棋小程序的框架内,我有几套这样的灰度/黑白(不确定): 有什么方法可以通过 Java 代码为 PNG 图片赋予色调?尝试用谷歌搜索此事,但没有找到任何真正符合我正在寻找的东西。 例如,对于下面
我有一个 CompilationUnit,其中包含一个未导入对另一个类的引用的类。Eclipse 轻松解决了此类问题,并建议导入缺少的类(位于父包中)。 如何在不知道其名称或位置的情况下以编程方式导入
我可以完全访问 Android 系统。我拥有所有 super 用户权限,可以从我的任何应用程序中执行所有操作。我只想实现一项功能,其中我需要重置设备而不将用户重定向到 PRIVACY_SETTINGS
Android Q 引入了一项设置,可以在应用程序上强制使用深色模式,而无需担心手动更改颜色:https://developer.android.com/preview/features/darkth
好的,所以我做了一些研究,似乎一致认为您不能以编程方式更新 android:updatePeriodMillis。 看来您必须改用 AlarmManager,这就像使用大锤来敲开坚果一样……奇怪的是
我正在努力在我的表格 View 中实现一些自定义操作。目前我在下面的代码中创建了一个自定义操作。 override func tableView(tableView: UITableView, edi
我有这个委托(delegate),它打算在用户用手指滚动时执行: -(void)scrollViewDidScroll:(UIScrollView *)scrollView 我有一行代码滚动到开头:
如果我们有这段代码: int a; cout > a; 在终端中,输入请求看起来像这样 please enter a value: _ 我如何以编程方式模拟用户在其中的输入。 最佳答案 下面是一个示例
是否可以通过 java 方法以编程方式重新呈现 a4j:outputPanel? 最佳答案 您可以保留民意调查,并在方法中设置一些标志(如果该标志已在民意调查中捕获),因为设置只是渲染面板 关于jav
我是一名优秀的程序员,十分优秀!