- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
是否可以将注释垂直居中放置在条形图上?它不能仅通过 annotation.stem.length 来实现。另一件事是使用 MutationObserver 设置注释的 y 位置,但我无法弄清楚如何获取栏的高度,所以我有引用我将在 y 属性上设置多少 y。有什么方法可以动态地将注释垂直居中放置在栏上吗?
google.charts.load("current", { packages: ["corechart", "bar"] });
google.charts.setOnLoadCallback(drawBVandBA);
function drawBVandBA() {
var dataArr = [
["Month", "Book Orders", "Buying Accounts", "Throughput"],
["Jan", 200.25, 1253, 379.09],
["Feb", 533.39, 1253, 379.09],
["March", 564.79, 1123, 379.09],
["Apr", 475.66, 1154, 379.09],
["May", 564.75, 1203, 379.09],
["Jun", 200.23, 1189, 379.09],
["Jul", 475.66, 1201, 379.09],
["Aug", 513.43, 1228, 379.09],
["Sep", 423.77, 1175, 379.09],
["Oct", 399.88, 1024, 379.09],
["Nov", 546.47, 1243, 379.09],
["Dec", 435.65, 1209, 379.09]
];
var data = google.visualization.arrayToDataTable(dataArr);
var view = new google.visualization.DataView(data);
view.setColumns([
0,
1,
{
calc: "stringify",
sourceColumn: 1,
type: "string",
role: "annotation"
},
2,
{
calc: "stringify",
sourceColumn: 2,
type: "string",
role: "annotation"
}
]);
var options = {
animation: {
duration: 1000,
easing: "out",
startup: true
},
annotations: {
textStyle: {
fontSize: 11,
color: "black",
auraColor: "none"
}
},
chartArea: {
backgroundColor: "#B9CDE5",
right: "6%",
width: "80%"
},
vAxes: {
0: {
viewWindowMode: "explicit",
viewWindow: {
max: 1400,
min: 0
},
gridlines: {
color: "transparent",
count: 8
}
},
1: {
viewWindow: {
max: 600,
min: 0
},
gridlines: {
color: "transparent",
count: 7
}
}
},
series: {
0: {
annotations: {
stem: {
length: 80
}
},
targetAxisIndex: 1,
color: "#4F81BD",
type: "bars"
},
1: {
annotations: {
stem: {
length: 7
}
},
type: "line",
targetAxisIndex: 0,
color: "#C0504D",
pointShape: "square",
pointsVisible: true
}
},
backgroundColor: "#8064A2",
legend: {
position: "top",
alignment: "start"
}
};
var container = document.getElementById("bv_and_ba");
var chart = new google.visualization.ColumnChart(container);
chart.draw(view, options);
}
<script src="https://www.gstatic.com/charts/loader.js"></script>
<div id="bv_and_ba" style="width: 100%; height: 300px;"></div>
最佳答案
有一个图表方法 --> chart.getChartLayoutInterface()
这会返回一个对象,它有自己的方法 --> getBoundingBox
它需要一个 id 字符串
条形元素的 id 字符串 = bar#series number#row number
第一个系列中的第一个柱 = bar#0#0
获取条的高度 --> chartLayout.getBoundingBox('bar#0#0')
一旦我们有了高度,我们就可以移动注释了
请参阅以下工作片段...
google.charts.load("current", { packages: ["corechart", "bar"] });
google.charts.setOnLoadCallback(drawBVandBA);
function drawBVandBA() {
var dataArr = [
["Month", "Book Orders", "Buying Accounts", "Throughput"],
["Jan", 200.25, 1253, 379.09],
["Feb", 533.39, 1253, 379.09],
["March", 564.79, 1123, 379.09],
["Apr", 475.66, 1154, 379.09],
["May", 564.75, 1203, 379.09],
["Jun", 200.23, 1189, 379.09],
["Jul", 475.66, 1201, 379.09],
["Aug", 513.43, 1228, 379.09],
["Sep", 423.77, 1175, 379.09],
["Oct", 399.88, 1024, 379.09],
["Nov", 546.47, 1243, 379.09],
["Dec", 435.65, 1209, 379.09]
];
var data = google.visualization.arrayToDataTable(dataArr);
var view = new google.visualization.DataView(data);
view.setColumns([0, 1, {
calc: "stringify",
sourceColumn: 1,
type: "string",
role: "annotation"
}, 2, {
calc: "stringify",
sourceColumn: 2,
type: "string",
role: "annotation"
}]);
var options = {
animation: {
duration: 1000,
easing: "out",
startup: true
},
annotations: {
textStyle: {
fontSize: 11,
color: "black",
auraColor: "none"
}
},
chartArea: {
backgroundColor: "#B9CDE5",
right: "6%",
width: "80%"
},
vAxes: {
0: {
viewWindowMode: "explicit",
viewWindow: {
max: 1400,
min: 0
},
gridlines: {
color: "transparent",
count: 8
}
},
1: {
viewWindow: {
max: 600,
min: 0
},
gridlines: {
color: "transparent",
count: 7
}
}
},
series: {
0: {
annotations: {
stem: {
color: 'transparent',
length: 0
}
},
targetAxisIndex: 1,
color: "#4F81BD",
type: "bars"
},
1: {
annotations: {
stem: {
length: 7
}
},
type: "line",
targetAxisIndex: 0,
color: "#C0504D",
pointShape: "square",
pointsVisible: true
}
},
backgroundColor: "#8064A2",
legend: {
position: "top",
alignment: "start"
}
};
var container = document.getElementById("bv_and_ba");
var chart = new google.visualization.ColumnChart(container);
var annotations = [];
var chartLayout;
var annotationsReady = false;
// get annotation text for element identification
google.visualization.events.addListener(chart, 'ready', function () {
chartLayout = chart.getChartLayoutInterface();
for (var i = 0; i < view.getNumberOfRows(); i++) {
annotations.push(view.getValue(i, 2));
}
});
// wait until annotations are ready to move
google.visualization.events.addListener(chart, 'animationfinish', function () {
annotationsReady = true;
moveAnnotations();
});
function moveAnnotations() {
// ensure annotations are ready
if (!annotationsReady) {
return;
}
// move annotations
Array.prototype.forEach.call(container.getElementsByTagName('text'), function(annotation) {
// exclude other labels
if (annotation.getAttribute('text-anchor') === 'middle') {
var annotationTop;
var barBounds;
// check if annotation to be moved
var rowIndex = annotations.indexOf(annotation.textContent);
if (rowIndex > -1) {
// get bar bounds
barBounds = chartLayout.getBoundingBox('bar#0#' + rowIndex);
// calculate annotation position
annotationTop = barBounds.top + (barBounds.height / 2) + (annotation.getBBox().height / 2);
// move annotation
annotation.setAttribute('y', annotationTop);
}
}
});
}
// prevent chart from moving annotations back to original position
var observer = new MutationObserver(moveAnnotations);
observer.observe(container, {
childList: true,
subtree: true
});
chart.draw(view, options);
}
<script src="https://www.gstatic.com/charts/loader.js"></script>
<div id="bv_and_ba" style="width: 100%; height: 300px;"></div>
关于javascript - 使用 Google Charts(组合图表)在其自己的栏上垂直居中注释,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51645153/
我想对齐输入,它有两个标签和一个没有任何标签的按钮,以便它们都在同一级别。 这是期望的效果: 这是我到目前为止得到的: 我通过在按钮前添加带有空白空间的标签,设法让它看起来像我想要的样子,但这并不理想
您好,我有一个关于 JavaFX 的问题。我担心答案是剥皮,我对此一无所知,但这里是。 我想在 JavaFX 中制作 Accordion/TabPane 交叉。我将尝试用文字解释自己,但在下面我已经包
这可能被认为是一个低俗的问题。然而,我还没有找到任何代码,也没有找到任何讨论如何用我的编程语言 C 来解决这个问题的论坛。已经进行了大量的尝试,并且最终都以实际上“硬编码”新数组而告终。 我正在尝试垂
我有以下代码: public Frame() { super(); setVisible(true); setDefaultCloseOperation(JFrame.EXIT
是否可以将 UIModalTransitionStyleFlipHorizontal 修改为垂直而不是水平? 我通常会使用 CATransition 来执行此操作,但该方法需要将一个 UIView
我有一个 ios5 导航的想法,我正在一个应用程序上做,我认为从 SOF 那里得到一些关于我的想法的建设性批评是明智的。 p> 想法: UIView 包含 6 个左右垂直堆叠的按钮 UIButtons
我正在努力进行一些 iOS 开发,我希望有人能够帮助我提出建议。我想实现一堆看起来像一副纸牌的 UIView。用户应该能够通过触摸刷出“卡片”。我想到了带有 pagingEnabled 的 UIScr
我想创建一个包含四张图片的入口页面作为指向其他页面的链接。但我希望这些图片显示在显示器的中间(垂直和水平)。我已经尝试了很多事情,但我做对了。我什至无法以任何方式垂直对齐图片(例如底部,您将在代码中看
我有代码在 div 的底部创建一个元素作为向下的“箭头/指针”。 我需要这样写,以便“箭头/指针”指向左侧 当前代码 - HTML 掩码 css 在 fiddle 中 https://j
下面的代码将焦点放在中间的 div 上,但该 div 出现在窗口的底部。如何使该 div 居中,使其显示在窗口的中心[垂直],而不设置固定位置。 $(function(){ $("#focus
这个问题在这里已经有了答案: Vertical Align Center in Bootstrap 4 [duplicate] (20 个答案) 关闭 4 年前。 我创建了一个由两列组成的结构,第一
演示:http://jsfiddle.net/vpH8r/2/ 我在上面创建了一个 jfiddle,试图让垂直滑动正常工作。 当前的问题是 slider 标签不会移动,并且不会出现从顶部到底部的干净滑
我正在尝试在 javascript 中创建一个垂直 slider 小部件。我不是在寻找任何插件或库,我正在尝试查看如何使用纯 javascript 完成它。我想我大概明白了。 请在此处查看到目前为止已
我正在尝试创建一个响应式导航列表,并将图像置于页面列表的中心 我已经设法接近那个,但是图像比列表更靠前。 我想像这样得到它,但似乎无法弄清楚。 任何帮助将不胜感激! 代码:https://jsfidd
有人可以帮我将导航栏居中,使其在页面上垂直居中吗? 我希望导航栏中央的链接位于顶部,而不是像现在这样向左浮动。 提前致谢 Toggle navigation
我想垂直、水平转换图像,并使用 javascript 缩放图像。目前我设法使调整大小的图像起作用,但它看起来不正确。我正在尝试使用类似于 Transform image 的东西.调整垂直移动条时,图像
这可能是一个问题,但要求太多,但我已经达到了我的极限。 我有这段 ( http://jsfiddle.net/3whTa/) CSS,它创建了一个箭头水平面包屑导航。 我想做的是将其转换为垂直。就像箭
我正在使用 opencv 进行非常简单的操作,但我无法理解为什么会出现此错误/问题。图像被操作到图像的一半(垂直)。 Mat img = imread("/Users/tanmoy/Documents
我想知道是否有人有任何技术来定位 css 生成的内容。例如: .block { height: 150px; width: 150px; border: 1px solid black;
关闭。这个问题需要更多 focused .它目前不接受答案。 想要改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭3年前。 Improve this que
我是一名优秀的程序员,十分优秀!