最近NVD3チャートを使い始めました。ハイチャートのようなズームオプションが好きです。出来ますか?HighchartsのようにNVD3チャートでズームオプションを使用することはできますか?
8
A
答えて
5
nv.models.lineWithFocusChart()
を使用する「ビューファインダを持つ折れ線グラフ」の例があります。このチャートタイプのスポーツをあなたはズームとチャートをパンするために使用することができ、メインチャートの下に追加の「ミニマップ」:
1
あなたのnvd3チャートにこの機能を適用することができます。 Highchartsのようにズームを補助するためのドラッグ可能なボックスはありませんが、ここに示すようにマウススクロールによるズームが可能です:pan+zoom example。スムーズなズームを実現するには、nvd3からトランジション/ディレイを削除する必要があります。今のところ、nvd3ソースファイルを変更して手動で行う必要があります。それについての議論がありますhere。
ここにはjsfiddleがあります。
function addZoom(options) {
// scaleExtent
var scaleExtent = 10;
// parameters
var yAxis = options.yAxis;
var xAxis = options.xAxis;
var xDomain = options.xDomain || xAxis.scale().domain;
var yDomain = options.yDomain || yAxis.scale().domain;
var redraw = options.redraw;
var svg = options.svg;
var discrete = options.discrete;
// scales
var xScale = xAxis.scale();
var yScale = yAxis.scale();
// min/max boundaries
var x_boundary = xScale.domain().slice();
var y_boundary = yScale.domain().slice();
// create d3 zoom handler
var d3zoom = d3.behavior.zoom();
// fix domain
function fixDomain(domain, boundary) {
if (discrete) {
domain[0] = parseInt(domain[0]);
domain[1] = parseInt(domain[1]);
}
domain[0] = Math.min(Math.max(domain[0], boundary[0]), boundary[1] - boundary[1]/scaleExtent);
domain[1] = Math.max(boundary[0] + boundary[1]/scaleExtent, Math.min(domain[1], boundary[1]));
return domain;
};
// zoom event handler
function zoomed() {
yDomain(fixDomain(yScale.domain(), y_boundary));
xDomain(fixDomain(xScale.domain(), x_boundary));
redraw();
};
// zoom event handler
function unzoomed() {
xDomain(x_boundary);
yDomain(y_boundary);
redraw();
d3zoom.scale(1);
d3zoom.translate([0,0]);
};
// initialize wrapper
d3zoom.x(xScale)
.y(yScale)
.scaleExtent([1, scaleExtent])
.on('zoom', zoomed);
// add handler
svg.call(d3zoom).on('dblclick.zoom', unzoomed);
};
// here chart is your nvd3 model
addZoom({
xAxis : chart.xAxis,
yAxis : chart.yAxis,
yDomain: chart.yDomain,
xDomain: chart.xDomain,
redraw : function() { chart.update() },
svg : svg
});
関連する問題
- 1. NVD3設定を使用すると、1つとして、グラフを持つことができますNVD3で
- 2. スクロールとズームオプションのMapViewのようなScrollviewを使用
- 3. princeXMLでhighchartsを使用するには?
- 4. Highcharts/highstock IEでチャートのタイトルを変更する方法は?
- 5. Node.jsがJavascriptエンジンとしてRhinoを使用できるようにすることはできますか?
- 6. このようにMySql CASEを使用できますか?
- 7. このようにAjaxPanelを使用できますか?
- 8. ここで私は選択イベントによってhighchartsで四角形を描画しています、私は、チャートの軸の値翻訳することによって、ボックスの座標を取得していますhighcharts
- 9. メソッドのようにEndOfStreamを使用することはできません
- 10. DataGridViewで複数行HeaderTextを使用できないようにすることはできますか?
- 11. 角度チャートを使用するときにデータポイントの色を関数で定義できますか? C3ライブラリで
- 12. CodeIgniterで.htaccessを使用してファイルに書き直すことはできませんか?このような
- 13. このループではどのようにopenMPを使用できますか?
- 14. directlabelsとggplot2はどのように使用できますか?
- 15. ジャスパーサーバーやIreportでJfreeチャートを使用できますか?
- 16. エンドユーザーがJavaScriptを使用してイベントをトリガーできないようにすることはできますか?
- 17. フォーマットHighchartsチャートtooltip pointFormat in formatter
- 18. HighChartsとDotNet.HighChartsを使用すると、シリーズ
- 19. ファイル名に「/」を使用することはできますか?
- 20. 私はどのように私の戻るボタンfunctionallytyをプログラムで使用することができますか?
- 21. dotchart highcharts dllを使用してMVC3でHighChartを表示するにはどうすればよいですか?
- 22. C#asp.netでどのようなオプションを使用してウェブサイトにチャートを描画できますか?
- 23. リストを使用することはできますがIListを使用することはできません。
- 24. TCLでは、このようにパラメータを渡すことはできますか?
- 25. Rails-projectをgemのように使うことはできますか?
- 26. どのように私は自分のアプリケーションでのマーキーを使用することができますか?
- 27. ベクトルでブーストアキュムレータを使用することはできますか?
- 28. Railsで「フロントコントローラ」を使用することはできますか?
- 29. jQueryをjavaScriptで使用することはできますか?
- 30. jettyでsocket.io.jsを使用することはできますか?
あなたのリンクは壊れています – Ofiris
ありがとう、それを修正しました。 –
散布図にこのような機能はありますか?そうでない場合は、どうすれば追加できますか? – Dinesh