Browse Source

fix overlap between multiline category xAxis and legend or axis label

pull/1858/head
Anthony Pessy 8 years ago
parent
commit
c52ee83c96
  1. 39
      src/axis.js
  2. 6
      src/core.js
  3. 6
      src/size.js

39
src/axis.js

@ -232,7 +232,7 @@ Axis.prototype.dyForXAxisLabel = function dyForXAxisLabel() {
if (config.axis_rotated) {
return position.isInner ? "1.2em" : -25 - this.getMaxTickWidth('x');
} else {
return position.isInner ? "-0.5em" : config.axis_x_height ? config.axis_x_height - 10 : "3em";
return position.isInner ? "-0.5em" : $$.getHorizontalAxisHeight('x') - 10;
}
};
Axis.prototype.dyForYAxisLabel = function dyForYAxisLabel() {
@ -265,12 +265,20 @@ Axis.prototype.textAnchorForY2AxisLabel = function textAnchorForY2AxisLabel() {
var $$ = this.owner;
return this.textAnchorForAxisLabel($$.config.axis_rotated, this.getY2AxisLabelPosition());
};
Axis.prototype.getMaxTickWidth = function getMaxTickWidth(id, withoutRecompute) {
Axis.prototype.getMaxTickBox = function getMaxTickBox(id, withoutRecompute) {
var $$ = this.owner, config = $$.config,
maxWidth = 0, targetsToShow, scale, axis, dummy, svg;
if (withoutRecompute && $$.currentMaxTickWidths[id]) {
return $$.currentMaxTickWidths[id];
targetsToShow, scale, axis, dummy, svg;
if (withoutRecompute && $$.currentMaxTickBoxes[id]) {
return $$.currentMaxTickBoxes[id];
}
var maxBox = {
height: 0,
width: 0
};
if ($$.svg) {
targetsToShow = $$.filterTargetsToShow($$.data.targets);
if (id === 'y') {
@ -284,18 +292,29 @@ Axis.prototype.getMaxTickWidth = function getMaxTickWidth(id, withoutRecompute)
axis = this.getXAxis(scale, $$.xOrient, $$.xAxisTickFormat, $$.xAxisTickValues, false, true, true);
this.updateXAxisTickValues(targetsToShow, axis);
}
dummy = $$.d3.select('body').append('div').classed('c3', true);
svg = dummy.append("svg").style('visibility', 'hidden').style('position', 'fixed').style('top', 0).style('left', 0),
svg = dummy.append("svg").style('visibility', 'hidden').style('position', 'fixed').style('top', 0).style('left', 0);
svg.append('g').call(axis).each(function () {
$$.d3.select(this).selectAll('text').each(function () {
var box = this.getBoundingClientRect();
if (maxWidth < box.width) { maxWidth = box.width; }
maxBox.width = Math.max(maxBox.width, box.width);
maxBox.height = Math.max(maxBox.height, box.height);
});
dummy.remove();
});
dummy.remove();
}
$$.currentMaxTickWidths[id] = maxWidth <= 0 ? $$.currentMaxTickWidths[id] : maxWidth;
return $$.currentMaxTickWidths[id];
$$.currentMaxTickBoxes[id] = maxBox;
return $$.currentMaxTickBoxes[id];
};
Axis.prototype.getMaxTickWidth = function getMaxTickWidth(id, withoutRecompute) {
return this.getMaxTickBox(id, withoutRecompute).width;
};
Axis.prototype.getMaxTickHeight = function getMaxTickHeight(id, withoutRecompute) {
return this.getMaxTickBox(id, withoutRecompute).height;
};
Axis.prototype.updateLabels = function updateLabels(withTransition) {

6
src/core.js

@ -153,11 +153,7 @@ c3_chart_internal_fn.initParams = function () {
$$.legendItemWidth = 0;
$$.legendItemHeight = 0;
$$.currentMaxTickWidths = {
x: 0,
y: 0,
y2: 0
};
$$.currentMaxTickBoxes = {};
$$.rotated_padding_left = 30;
$$.rotated_padding_right = config.axis_rotated && !config.axis_x_show ? 0 : 30;

6
src/size.js

@ -100,8 +100,12 @@ c3_chart_internal_fn.getHorizontalAxisHeight = function (axisId) {
}
if (axisId === 'y2' && !config.axis_y2_show) { return $$.rotated_padding_top; }
// Calculate x axis height when tick rotated
if (axisId === 'x' && !config.axis_rotated && config.axis_x_tick_rotate) {
if (axisId === 'x' && !config.axis_rotated) {
if (config.axis_x_tick_rotate) {
h = 30 + $$.axis.getMaxTickWidth(axisId) * Math.cos(Math.PI * (90 - config.axis_x_tick_rotate) / 180);
} else {
h = 30 + $$.axis.getMaxTickHeight(axisId);
}
}
// Calculate y axis height when tick rotated
if (axisId === 'y' && config.axis_rotated && config.axis_y_tick_rotate) {

Loading…
Cancel
Save