- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
类 ScatteredCell:UICollectionViewCell、CPTScatterPlotDataSource、CPTPlotDataSource、CPTScatterPlotDelegate{ @IBOutlet var hostView:CPTGraphHostingView!
var plot1: CPTBarPlot!
var plot2: CPTBarPlot!
var plot3: CPTScatterPlot!
var indexOfCell:Int? = nil
var selectedComponent: String!
let BarWidth = 0.8
let BarInitialX = 1.0
let yArray = [0,0,3,0,2,1,0,1,5,0,0,5,8,0,0,1,0,0,6,0,7,0,3,5,5,0,2,0,0,1,0]
var valueBarPlot:Array<Any> = []
var fullBarPlot:Array<Any> = []
var yIntervalLength = NSNumber()
var yAxisScale = 0
override func awakeFromNib()
{
super.awakeFromNib()
}
override func draw(_ rect: CGRect) {
self.layer.borderWidth = 1
self.layer.borderColor = UIColor(red: 204.0/255.0, green: 204.0/255.0, blue: 204.0/255.0, alpha: 1).cgColor
}
func initWithPlot()
{
configureHostView()
configureGraph()
configureChart()
configureAxes()
configureLegend()
}
func configureHostView()
{
hostView.allowPinchScaling = false
}
func configureGraph()
{
// 1 - Create the graph
let graph = CPTXYGraph(frame: hostView.bounds)
graph.plotAreaFrame?.masksToBorder = false
hostView.hostedGraph = graph
// 2 - Configure the graph
graph.fill = CPTFill(color: CPTColor.clear())
graph.paddingBottom = 40.0
graph.paddingLeft = 20.0
graph.paddingTop = 20.0
graph.paddingRight = 15.0
let yLabelFormatter = NumberFormatter()
yLabelFormatter.generatesDecimalNumbers = false
// 4 - Set up plot space
guard let plotSpace = graph.defaultPlotSpace as? CPTXYPlotSpace else { return }
plotSpace.yRange = CPTPlotRange(location: 0, length:yAxisScale as NSNumber)
var yAxisLength:NSNumber = 0
if selectedComponent == "month"{
yAxisLength = 31
}else {
yAxisLength = 12
}
plotSpace.xRange = CPTPlotRange(location:0.5, length:yAxisLength)
let axisSet = (graph.axisSet as? CPTXYAxisSet)
let axisSet1 = (graph.axisSet as? CPTXYAxisSet)
let y: CPTXYAxis? = axisSet?.yAxis
y?.labelFormatter = yLabelFormatter
y?.axisConstraints = CPTConstraints.init(lowerOffset: -25.0)
y?.plotSpace = plotSpace
let x: CPTXYAxis? = axisSet?.xAxis
x?.labelFormatter = yLabelFormatter
graph.masksToBorder = true
}
func configureChart()
{
// 1 - take plot
plot1 = CPTBarPlot()
plot1.fill = CPTFill(color: CPTColor.init(componentRed: 25.0/255.0, green: 100.0/255.0, blue: 150.0/255.0, alpha: 1))
plot2 = CPTBarPlot()
plot2.fill = CPTFill(color: CPTColor.init(componentRed: 230.0/255.0, green: 230.0/255.0, blue: 230.0/255.0, alpha: 1))
// 2 - Set up line style
let barLineStyle = CPTMutableLineStyle()
barLineStyle.lineColor = CPTColor.clear()
barLineStyle.lineWidth = 1
// 3 - configure plots to graph
let barX = BarInitialX
let plot:CPTBarPlot = plot1!
plot.dataSource = self
//plot.delegate = self
plot.barWidth = NSNumber(value: BarWidth)
plot.barOffset = NSNumber(value: barX)
plot.lineStyle = barLineStyle
// barX += BarWidth
let splot:CPTBarPlot = plot2!
splot.dataSource = self
//Add plots to graph
guard let graph = hostView.hostedGraph else { return }
graph.add(splot, to: graph.defaultPlotSpace)
graph.add(plot, to: graph.defaultPlotSpace)
let myBorderLineStyle = CPTMutableLineStyle()
myBorderLineStyle.lineColor = CPTColor.clear()
plot2.lineStyle = myBorderLineStyle
plot2.barWidth = NSNumber(value: BarWidth)
plot2.barOffset = NSNumber(value: barX)
plot3 = CPTScatterPlot()
let scatplot:CPTScatterPlot = plot3!
scatplot.dataSource = self
//Add plots to graph
guard let graph1 = hostView.hostedGraph else { return }
graph1.add(scatplot, to: graph.defaultPlotSpace)
plot1.attributedTitle = attributedString("DISTANCE TRAVELLED(MILES)",fontSize: 7.0)
plot3.title = "" //attributedString("TIME(HOURS)",fontSize: 8.0)
}
func configureAxes()
{
// 1 - Configure styles
let axisLineStyle = CPTMutableLineStyle()
//let axisLineStyle = CPTMutableLineStyle()
axisLineStyle.lineWidth = 2.0
axisLineStyle.lineColor = CPTColor.clear()
// 2 - Get the graph's axis set
guard let axisSet = hostView.hostedGraph?.axisSet as? CPTXYAxisSet else { return }
let axisTextStyle = CPTMutableTextStyle()
axisTextStyle.fontName = "Reg"
let axisFormatter = NumberFormatter()
axisFormatter.minimumIntegerDigits = 1
// 3 - Configure the x-axis
if let x = axisSet.xAxis {
var xAxisInterval:NSNumber = 0
if selectedComponent == "month"{
xAxisInterval = 5
}else {
xAxisInterval = 1
}
x.majorIntervalLength = xAxisInterval
x.orthogonalPosition = 0
x.minorTicksPerInterval = 2
x.majorTickLength = 5
x.attributedTitle = attributedString("MONTH",fontSize: 9.0)
axisTextStyle.color = CPTColor.gray()
axisTextStyle.fontSize = 6.0
x.labelTextStyle = axisTextStyle
}
//if 4 - Configure the y-axis
if let y = axisSet.yAxis{
let identi = y.identifier
print(identi)
y.majorIntervalLength = yIntervalLength
y.majorTickLength = 5
y.minorTicksPerInterval = 1
y.orthogonalPosition = 0
y.axisConstraints = CPTConstraints.init(lowerOffset: 5.0)
axisTextStyle.color = CPTColor.init(componentRed: 25.0/255.0, green: 100.0/255.0, blue: 150.0/255.0, alpha: 1)
axisTextStyle.fontSize = 6.0
y.labelTextStyle = axisTextStyle
y.labelFormatter = axisFormatter
}
}
func configureLegend() {
guard let graph = hostView.hostedGraph else { return }
let legend = CPTLegend(graph: graph)
graph.legend = legend
graph.legendAnchor = .topLeft
graph.legendDisplacement = CGPoint(x: 25.0, y: 0.0)
legend.fill = CPTFill(color: CPTColor.white())
legend.swatchSize = CGSize(width: 10.0, height: 10.0)
let titleStyle = CPTMutableTextStyle()
titleStyle.color = CPTColor.black()
titleStyle.fontSize = 11.0
legend.textStyle = titleStyle
legend.delegate = self
}
func attributedString(_ title:String, fontSize:CGFloat) -> NSAttributedString? {
let attributes = [
NSFontAttributeName : UIFont(name: Font.Bold, size: fontSize) ?? UIFont.systemFont(ofSize: 17.0),
NSForegroundColorAttributeName : UIColor(red: 127.0/255.0, green: 137.0/255.0, blue: 147.0/255.0, alpha: 1),
] as [String : Any]
let attributedString = NSAttributedString(string: title, attributes: attributes)
return attributedString
}
// MARK: - Plot Data Source Methods
func numberOfRecords(for plot: CPTPlot) -> UInt
{
return UInt(valueBarPlot.count)
}
func number(for plot: CPTPlot, field fieldEnum: UInt, record idx: UInt) -> Any?
{
if fieldEnum == UInt(CPTBarPlotField.barTip.rawValue)
{
if plot == plot1
{
return self.valueBarPlot[Int(idx)] as! NSNumber;
}
if plot == plot2
{
return self.fullBarPlot[Int(idx)] as! NSNumber;
}
if plot == plot3
{
return self.yArray[Int(idx)] as NSNumber;
}
}
return idx
}
}
问题 1:如果我在 Y 轴上使用 upperoffset,我将无法绘制第二个 y 轴
问题2:在Collectionviewcell中填充Host View ,它有4个图表,所以我使用了collectionview单元,我不知道为什么图表在真实设备中变得模糊
最佳答案
提供的代码中没有提及第二个 y 轴。您需要创建并配置一个新的轴对象并将其添加到轴集中。有关示例代码,请参阅Plot Gallery示例应用程序中的“Axis Demo”。
graph.axisSet.axes = [x, y, y2]
很明显,图形托管 View 在单元格内的位置不正确。从提供的信息中我无法判断原因。
关于ios - 核心图如何绘制 2 y 轴标签,图形看起来模糊,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45005276/
我正在学习 Javascript,我正在尝试创建一个简单的下拉菜单。我想要的功能的示例可以在 Google 主页的顶部菜单中看到,其中包含“更多”和“设置”下拉菜单。 我有一个使用 onclick()
我尝试捕捉 tinyMce 编辑器的模糊和焦点事件。 我为此找到了以下方法。 ed.onInit.add(function(ed) { tiny
这里完全被难住了。尝试一些很简单的东西,但它不起作用: $("input.input1, textarea.input1").focus(function(){ $(this).addClas
我有以下 jQuery 函数: 提交表单 $(".content").delegate('.entryButton','click', function() {var form = $(this).c
如何使用 jQuery 在焦点/模糊上切换元素的 CSS? $('.answerSpace').bind('blur', function(){ $('.normProf').toggleClass(
在我的 iPhone 应用程序中,我有一个黑白 UIImage。我需要模糊该图像(高斯模糊即可)。 iPhone 显然知道如何模糊图像,如 it does that when it draws sha
这个问题已经有答案了: Blurring an image via CSS? (6 个回答) 已关闭 7 年前。 我有一个场景。我想随着循环的进行模糊我的图像。我怎样才能做到这一点?这是我的代码。
这个错误是在子字符串方法上抛出的,我发现很多线程都在处理这个问题,但我遇到的问题似乎有所不同。我知道如果您的字符串短于子字符串(开始,结束)大小,它会抛出此错误,但在任何内容传递到方法调用之前都会抛出
是否有简单的解决方案可以在 Qt 中为图像添加运动模糊?还没有找到任何关于模糊的好教程。我需要一些非常简单的东西,我可以理解,如果我可以改变模糊角度,那就太好了。 最佳答案 Qt 没有运动模糊过滤器。
我的搜索框在正常状态下很小。焦点对准时,它会展开,并显示一个提交按钮。这样做是为了节省空间。现在,在模糊时,搜索框再次缩小,提交按钮消失。 问题是,通过使提交按钮成为“竞赛”以在正确的位置单击它,对提
您好,我正在使用 PngBitmapEncoder 从 Canvas 在内存中创建图像。 public void CaptureGraphic() { Canvas canvas = new
我已经搜索过谷歌、这个和其他论坛,但无济于事……太棒了,有没有可能有像 onMiddleClick="blur();"这样的东西?在单击鼠标中键时隐藏链接的焦点边框? 最佳答案 $('a').clic
我无法在我的应用程序中正确渲染我的纹理。我使用的艺术品是精确的,并且已经缩放且尺寸合适,但是当我在手机上渲染它时,我的纹理突然不如原始艺术品清晰/精确,我不明白为什么。 有人遇到过这个问题吗? 最佳答
这里有与上述主题相同的问题但没有得到答复 我这里有布局 我需要在底部布局中使用与顶部布局相同的图像,但使用模糊样式 设置 alpha 没有帮助 - TextView 也会影响 如何虚化down布局的背
我已经搜索了一段时间,但到目前为止没有找到适合我需要的东西。 ( This was helpful, but not convincing ) 从两个不同的来源,我得到两个不同的字符串。我想检查较短的
我有这样的代码: var passwordTextBox = angular.element("#password"); passwordTextBox.blur(function()
设置此 JQuery 函数无法正常工作。有时,如果我单击元素,什么也没有发生,并且它会触发隐藏可折叠菜单的功能,如果单击文档上的任意位置,则不会重定向到正确的 href。有什么更好的方法吗? HTML
尝试通过将坐标列表保存到数组来在多个位置裁剪我的图像后,裁剪区域中的字母变得非常模糊,我无法弄清楚原因。 原图看起来像 裁剪后的图像看起来像 题中代码如下: import numpy as np im
我知道我们可以调暗/模糊屏幕,如 this post 所示. 我应该怎么做才能使它的一部分变暗/模糊,使单个(或多个) View 没有任何效果,从而使整个屏幕具有突出显示 View 的效果? 此外,即
如果有人曾经向 digg 提交过故事,它会检查该故事是否已经提交,我假设是通过模糊搜索。 我想实现类似的东西,想知道他们是否使用开源的 php 类? Soundex 不这样做,句子/字符串的长度可达
我是一名优秀的程序员,十分优秀!