- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
最佳答案
编辑:此功能现已添加到 Chaco 4.6 中,因此如果您使用的是此版本或更高版本,请使用以下类似代码。如果没有请看下面的原帖。另请参阅文档 here另一个例子here .
if __name__ == "__main__":
from traits.etsconfig.api import ETSConfig
ETSConfig.toolkit = 'qt4'
#
import warnings
warnings.filterwarnings(action = "ignore", category = FutureWarning, module="chaco")
warnings.filterwarnings(action = "ignore", category = FutureWarning, module="traits")
#
from PySide import QtGui, QtCore
import numpy as np
from enable.api import Component, Container, Window
from chaco.api import *
import sys
#
class ChacoPlot(QtGui.QWidget):
def __init__(self, parent=None):
super(ChacoPlot, self).__init__(parent)
#
self.container = OverlayPlotContainer(padding=40)
#
self.enableWindow = Window(self, -1, component=self.container)
windowLayout = QtGui.QVBoxLayout(self)
windowLayout.addWidget(self.enableWindow.control)
#
self.xRange = DataRange1D()
self.yRange = DataRange1D()
#
self.xMapper = LinearMapper(range=self.xRange)
self.yMapper = LinearMapper(range=self.yRange)
#
self.plots = {}
# keep a list of plots added to the container
#
def setMinimumSize(self, width, height):
self.enableWindow.control.setMinimumSize(width, height)
#
def addLine(self, name, plotType):
xSource = ArrayDataSource([0])
ySource = ArrayDataSource([0])
#
self.xRange.add(xSource)
self.yRange.add(ySource)
#
index_mapper = self.xMapper
value_mapper = self.yMapper
#
# plotType is a class name
plot = plotType( index = xSource,
value = ySource,
index_mapper = index_mapper,
value_mapper = value_mapper,
visible = False
)
#
self.container.add(plot)
#
self.plots[name] = {'plot':plot, 'xSource':xSource, 'ySource':ySource}
#
def updateLine(self, name, xData, yData):
plot = self.plots[name]
#
if np.array(xData).size != 0:
plot['plot'].visible = True
else:
plot['plot'].visible = False
xData = [0]
yData = [0]
#
plot['xSource'].set_data(xData)
plot['ySource'].set_data(yData)
#
def addAxis(self, plotName, orientation):
plot = self.plots[plotName]['plot']
#
if orientation == 'top' or orientation == 'bottom':
mapper = self.xMapper
if orientation == 'left' or orientation == 'right':
mapper = self.yMapper
#
axis = PlotAxis(plot, orientation=orientation, mapper=mapper)
plot.overlays.append(axis)
#
return axis
#
def addMinorAxis(self, plotName, orientation):
plot = self.plots[plotName]['plot']
#
if orientation == 'top' or orientation == 'bottom':
mapper = self.xMapper
range = self.xRange
if orientation == 'left' or orientation == 'right':
mapper = self.yMapper
range = self.yRange
#
newAxis = MinorPlotAxis(plot, orientation=orientation, mapper=mapper)
plot.overlays.append(newAxis)
#
return axis
#
#
if __name__ == "__main__":
appQT = QtGui.QApplication.instance()
#
x1 = np.arange(300)/18.0
y1 = np.sin(x1)
x2 = np.arange(300)/18.0
y2 = 2.0*np.cos(x2)
#
plot = ChacoPlot()
plot.setMinimumSize(400,300)
#
plot.addLine('line1', LinePlot)
plot.addLine('line2', LinePlot)
plot.updateLine('line1', x1, y1)
plot.updateLine('line2', x2, y2)
#
plot.addAxis('line1', 'bottom')
plot.addAxis('line1', 'left')
plot.addMinorAxis('line1', 'bottom')
plot.addMinorAxis('line1', 'left')
#
plot.show()
appQT.exec_()
原文: Chaco 没有专门提供此功能,但您可以通过添加额外的 PlotAxis
来添加小刻度。 。您需要修改轴的一些属性:
tick_generator
- 该对象定义刻度的位置tick_label_formatter
- 此函数返回给定刻度标签值的刻度标签字符串tick_in
和 tick_out
- 这些数字定义刻度的大小(轴内和轴外)这是一个例子。代码很多,但相当简单。尽管人们通常使用 Plot
来绘制图。辅助类,我喜欢手动创建绘图,因为它更容易自定义。无论如何希望它能有所帮助。
if __name__ == "__main__":
from traits.etsconfig.api import ETSConfig
ETSConfig.toolkit = 'qt4'
#
import warnings
warnings.filterwarnings(action = "ignore", category = FutureWarning, module="chaco")
warnings.filterwarnings(action = "ignore", category = FutureWarning, module="traits")
#
from PySide import QtGui, QtCore
import numpy as np
from enable.api import Component, Container, Window
from chaco.api import *
import sys
#
class ChacoPlot(QtGui.QWidget):
def __init__(self, parent=None):
super(ChacoPlot, self).__init__(parent)
#
self.container = OverlayPlotContainer(padding=40)
#
self.enableWindow = Window(self, -1, component=self.container)
windowLayout = QtGui.QVBoxLayout(self)
windowLayout.addWidget(self.enableWindow.control)
#
self.xRange = DataRange1D()
self.yRange = DataRange1D()
#
self.xMapper = LinearMapper(range=self.xRange)
self.yMapper = LinearMapper(range=self.yRange)
#
self.plots = {}
# keep a list of plots added to the container
#
def setMinimumSize(self, width, height):
self.enableWindow.control.setMinimumSize(width, height)
#
def addLine(self, name, plotType):
xSource = ArrayDataSource([0])
ySource = ArrayDataSource([0])
#
self.xRange.add(xSource)
self.yRange.add(ySource)
#
index_mapper = self.xMapper
value_mapper = self.yMapper
#
# plotType is a class name
plot = plotType( index = xSource,
value = ySource,
index_mapper = index_mapper,
value_mapper = value_mapper,
visible = False
)
#
self.container.add(plot)
#
self.plots[name] = {'plot':plot, 'xSource':xSource, 'ySource':ySource}
#
def updateLine(self, name, xData, yData):
plot = self.plots[name]
#
if np.array(xData).size != 0:
plot['plot'].visible = True
else:
plot['plot'].visible = False
xData = [0]
yData = [0]
#
plot['xSource'].set_data(xData)
plot['ySource'].set_data(yData)
#
def addAxis(self, plotName, orientation):
plot = self.plots[plotName]['plot']
#
if orientation == 'top' or orientation == 'bottom':
mapper = self.xMapper
if orientation == 'left' or orientation == 'right':
mapper = self.yMapper
#
axis = PlotAxis(plot, orientation=orientation, mapper=mapper)
plot.overlays.append(axis)
#
return axis
#
def addMinorAxis(self, plotName, orientation):
plot = self.plots[plotName]['plot']
#
if orientation == 'top' or orientation == 'bottom':
mapper = self.xMapper
range = self.xRange
if orientation == 'left' or orientation == 'right':
mapper = self.yMapper
range = self.yRange
#
newAxis = PlotAxis(plot, orientation=orientation, mapper=mapper)
plot.overlays.append(newAxis)
#
newAxis.tick_generator = MinorTickGenerator()
#
newAxis.tick_label_formatter = lambda x: ''
newAxis.tick_in = 2
newAxis.tick_out = 2
#
#
class MinorTickGenerator(AbstractTickGenerator):
def __init__(self):
super(MinorTickGenerator, self).__init__()
#
def get_ticks(self, data_low, data_high, bounds_low, bounds_high, interval, use_endpoints=False, scale='linear'):
interval = interval
#
if interval == 'auto':
interval = auto_interval(data_low, data_high)/5.0
#
return auto_ticks(data_low, data_high, bounds_low, bounds_high, interval, use_endpoints)
#
#
if __name__ == "__main__":
appQT = QtGui.QApplication.instance()
#
x1 = np.arange(300)/18.0
y1 = np.sin(x1)
x2 = np.arange(300)/18.0
y2 = 2.0*np.cos(x2)
#
plot = ChacoPlot()
plot.setMinimumSize(400,300)
#
plot.addLine('line1', LinePlot)
plot.addLine('line2', LinePlot)
plot.updateLine('line1', x1, y1)
plot.updateLine('line2', x2, y2)
#
plot.addAxis('line1', 'bottom')
plot.addAxis('line1', 'left')
plot.addMinorAxis('line1', 'bottom')
plot.addMinorAxis('line1', 'left')
#
plot.show()
appQT.exec_()
关于python - Chaco 图中的小刻度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34755769/
如何使用 plot() 在 XY 图中绘制第二条线,以不同的比例(如本例(紫色线))? 第一行(红色)我的 R 代码是这样的: p <- sqlQuery(ch,"SELECT wl,param1 F
我正在寻找一种将折线图步骤设置为仅完整数字步骤的方法,例如 1,2,3,4,5..... 目前它看起来像这样: 这些是我的选择。我搜索了很多但找不到解决方案。 let options = {
我的问题是如何将 Y 轴刻度的间隔从 0.2 更改为 0.1?我已经尝试了一切,但我很困!帖子底部堆叠条形图的图片 dpi=600 #pixels per square inch A <- c(
有没有办法根据当前数据集在 D3 轴上动态设置 ticks。我遇到的问题是我的时间范围(x 轴)可能变化很大。对于一些数据集来说,它是几年的值(value),对于其他数据集来说是几个月,在某些情况下只
我已经使用默认参数创建了一个 dojo 蜘蛛图。我需要隐藏轴标签(刻度上的数据值,而不是轴标题)。 我已经尝试过'ticks: false',但是它不适用于蜘蛛图。 require(["dojo/_b
有没有一种简单的方法可以在绘图 Axis 上获得自定义缩放比例? 例如,semilogy 函数提供 {x, log10(y)} 缩放比例,这样就可以自动放大/缩小并自动调整刻度和标签。我想对 {x,
如何修改图形和图表的 y Axis 刻度?我想要这样的东西:my_figure.y_range.end = my_figure.y_range.end * 1.3 所以我想要更高一点的y轴。谢谢! 最
我正在尝试使用 recharts 添加图表一些货币的最新汇率。数据显示正确,但图表始终从 0 开始并略高于最大值。 图表是正确的,但它不需要从 0 开始,因为这样做,它几乎是一条线。 这是图表的图片:
我有一个 SWT Scale 小部件,我需要在刻度上的刻度上添加标签。 有没有办法做到这一点?也许在 slider 小部件上? 谢谢 最佳答案 这可能不是您所要求的,但您可以在 Scale 小部件旁边
这是一个从 .xlsx 文件中读取数据并利用 Plotly 库绘制气泡图的程序。这是 .xlsx 文件的原始数据: 1991 1992 1993 1994 1995
我这里有一个代码笔 - https://codepen.io/anon/pen/yvgJKB 我有一个简单的堆积条形图。 我想将其制作成一个组件,因此我需要传入值以使其可重用 x 缩放函数返回d.da
让我们看一个基本的演示折线图: jsfiddle $(function () { $('#container').highcharts({ //all the code there 我想强制
是否可以在 t-sql 中获得像 DateTime.Ticks 这样的 C# 内容? 感谢帮助 最佳答案 您不太可能从 SQL 中获得与 DateTime.Ticks 相同的精度,因为 SQL 不能以
我正在使用 Bokeh 生成散点图,每个 X 值具有不同的 Y 值。当 Bokeh 生成绘图时,它会根据绘制的值的数量自动填充 x 轴间距。我希望 x 轴上的所有值均匀分布,无论单个数据点的数量如何。
我使用下面的代码使用谷歌图表生成折线图 google.charts.load('current', {packages: ['corechart', 'line']});
我正在尝试在 d3 中构建堆积条形图。 这是我的 jsfiddle: http://jsfiddle.net/maneesha/gwjkgruk/4/ 我正在尝试修复它,使 y 轴从零开始。 我认为这
我有一个 d3 时间刻度图表。目前,轴刻度为每个数据对象呈现一个日期。例如,数据的范围可以是 1 天的数据、1 个月内 2 周的数据、5 个月的数据甚至更多。 理想情况下,我们希望显示带有周数的刻度,
当使用“Cassic”折线图时,我可以为 hAxis 分配刻度,还有这样的格式和标题: var options = { hAxis: { format:'h a', title
我的累积折线图没有正确构建 yScale。 给定要构建图表的数据: var data = [{ key: "Page view", values: [ ["2013-07-01 00:
在 y 轴上使用两个具有正常整数值的 DateAxisSeries(x 轴)我的 jqPlot 将 y 刻度呈现两次。 像这样: 2| 2| 1| 1| 0|_____________________
我是一名优秀的程序员,十分优秀!