hqchart 1.1.14446 → 1.1.14452

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -4460,6 +4460,8 @@ function JSChart(divElement, bOffscreen, bCacheCanvas)
4460
4460
  if (IFrameSplitOperator.IsNumber(item.PriceFormatType)) chart.ChartCorssCursor.StringFormatY.PriceFormatType=item.PriceFormatType;
4461
4461
  if (IFrameSplitOperator.IsNumber(item.DataFormatType)) chart.ChartCorssCursor.StringFormatY.DataFormatType=item.DataFormatType;
4462
4462
  if (IFrameSplitOperator.IsBool(item.EnableKeyboard)) chart.ChartCorssCursor.EnableKeyboard=item.EnableKeyboard;
4463
+
4464
+ if (IFrameSplitOperator.IsBool(item.IsShowCorssPoint)) chart.ChartCorssCursor.CorssPointConfig.Enable=item.IsShowCorssPoint;
4463
4465
 
4464
4466
  }
4465
4467
 
@@ -4953,6 +4955,7 @@ function JSChart(divElement, bOffscreen, bCacheCanvas)
4953
4955
  if (IFrameSplitOperator.IsNumber(item.HPenType)) chart.ChartCorssCursor.HPenType=item.HPenType;
4954
4956
  if (IFrameSplitOperator.IsNumber(item.VPenType)) chart.ChartCorssCursor.VPenType=item.VPenType;
4955
4957
  if (IFrameSplitOperator.IsBool(item.EnableKeyboard)) chart.ChartCorssCursor.EnableKeyboard=item.EnableKeyboard;
4958
+ if (IFrameSplitOperator.IsBool(item.IsShowCorssPoint)) chart.ChartCorssCursor.CorssPointConfig.Enable=item.IsShowCorssPoint;
4956
4959
  }
4957
4960
 
4958
4961
  if (option.MinuteInfo) chart.CreateMinuteInfo(option.MinuteInfo);
@@ -6844,6 +6847,7 @@ var JSCHART_MENU_ID=
6844
6847
  CMD_CORSS_ON_CLOSE_LINE_ID:49, //十字光标在价格线上(分时图)
6845
6848
  CMD_CORSS_ON_VAILD_TIME_ID:50, //超出当前时间的,X轴调整到当前最后的时间(分时图)
6846
6849
  CMD_CORSS_ON_KLINE_ID:51, //十字光标只能画在K线上
6850
+ CMD_CORSS_POINT_ID:52, //十字光标圆点
6847
6851
 
6848
6852
 
6849
6853
 
@@ -14246,6 +14250,9 @@ function JSChartContainer(uielement, OffscreenElement, cacheElement)
14246
14250
  this.ChartCorssCursor.IsShowClose=srcParam;
14247
14251
  }
14248
14252
  break;
14253
+ case JSCHART_MENU_ID.CMD_CORSS_POINT_ID:
14254
+ if (IFrameSplitOperator.IsBool(srcParam) && this.ChartCorssCursor) this.ChartCorssCursor.CorssPointConfig.Enable=srcParam;
14255
+ break;
14249
14256
  }
14250
14257
  }
14251
14258
 
@@ -44787,9 +44794,10 @@ function ChartMultiBar()
44787
44794
  var groupItem=this.Bars[i];
44788
44795
  if (!groupItem || !IFrameSplitOperator.IsNonEmptyArray(groupItem.Point)) continue;
44789
44796
 
44790
- var clrConfig= { Color:groupItem.Color, Width:null, Name:groupItem.Name, Type:0 };
44797
+ var clrConfig= { Color:groupItem.Color, BGColor:null, Width:null, Name:groupItem.Name, Type:0 };
44791
44798
  if (IFrameSplitOperator.IsNumber(groupItem.Width)) clrConfig.Width=groupItem.Width;
44792
44799
  if (IFrameSplitOperator.IsNumber(groupItem.Type)) clrConfig.Type=groupItem.Type;
44800
+ if (groupItem.BorderColor) clrConfig.BorderColor=groupItem.BorderColor;
44793
44801
 
44794
44802
  for(var j=0; j<groupItem.Point.length; ++j)
44795
44803
  {
@@ -44910,8 +44918,9 @@ function ChartMultiBar()
44910
44918
 
44911
44919
  var config=null;
44912
44920
  var path=new Path2D();
44921
+ var pathBG=new Path2D();
44913
44922
  var count=0;
44914
- var drawType=-1; //1=直线 2=实心 3=空心
44923
+ var drawType=-1; //1=直线 2=实心 3=空心 4=边框+背景
44915
44924
  var barWidth=dataWidth; //默认K线宽度
44916
44925
  this.Canvas.beginPath();
44917
44926
  for(var i=0;i<aryBar.length;++i)
@@ -44926,6 +44935,7 @@ function ChartMultiBar()
44926
44935
  {
44927
44936
  if (config.Type==0) drawType=2; //实心
44928
44937
  else if (config.Type==1) drawType=3; //空心
44938
+ else if (config.Type==2) drawType=4; //边框+背景
44929
44939
  else continue;
44930
44940
  }
44931
44941
  else //太细了, 直线
@@ -44982,6 +44992,31 @@ function ChartMultiBar()
44982
44992
  path.addPath(barPath);
44983
44993
  ++count;
44984
44994
  }
44995
+ else if (drawType==4) //背景+边框
44996
+ {
44997
+ var x=item.X-(barWidth/2);
44998
+ var y=Math.min(item.Y,item.Y2);
44999
+ var barWidth=barWidth;
45000
+ var barHeight=Math.abs(item.Y-item.Y2);
45001
+
45002
+ var barPath = new Path2D();
45003
+ if (this.IsHScreen)
45004
+ barPath.rect(ToFixedRect(y),ToFixedRect(x),ToFixedRect(barHeight),ToFixedRect(barWidth))
45005
+ else
45006
+ barPath.rect(ToFixedRect(x),ToFixedRect(y),ToFixedRect(barWidth),ToFixedRect(barHeight))
45007
+
45008
+ pathBG.addPath(barPath);
45009
+
45010
+ var barPath = new Path2D();
45011
+ if (this.IsHScreen)
45012
+ barPath.rect(ToFixedPoint(y),ToFixedPoint(x),ToFixedPoint(barHeight),ToFixedPoint(barWidth))
45013
+ else
45014
+ barPath.rect(ToFixedPoint(x),ToFixedPoint(y),ToFixedPoint(barWidth),ToFixedPoint(barHeight))
45015
+
45016
+ path.addPath(barPath);
45017
+
45018
+ ++count;
45019
+ }
44985
45020
  }
44986
45021
 
44987
45022
 
@@ -45004,6 +45039,21 @@ function ChartMultiBar()
45004
45039
  this.Canvas.strokeStyle=config.Color;
45005
45040
  this.Canvas.stroke(path);
45006
45041
  }
45042
+ else if (drawType==4)
45043
+ {
45044
+ if (config.Color)
45045
+ {
45046
+ this.Canvas.fillStyle=config.Color; //背景填充颜色
45047
+ this.Canvas.fill(path);
45048
+ }
45049
+
45050
+ if (config.BorderColor)
45051
+ {
45052
+ this.Canvas.lineWidth=1*pixelRatio;
45053
+ this.Canvas.strokeStyle=config.BorderColor;
45054
+ this.Canvas.stroke(path);
45055
+ }
45056
+ }
45007
45057
  }
45008
45058
 
45009
45059
  }
@@ -57411,6 +57461,13 @@ function ChartCorssCursor()
57411
57461
  this.IsFixXLastTime=false; //是否修正X轴,超出当前时间的,X轴调整到当前最后的时间.
57412
57462
  this.IsDrawXRangeBG=false; //是否绘制十字光标背景
57413
57463
 
57464
+ this.CorssPointConfig=
57465
+ {
57466
+ Enable:false,
57467
+ Center:CloneData(g_JSChartResource.CorssCursor.CorssPoint.Center),
57468
+ Border:CloneData(g_JSChartResource.CorssCursor.CorssPoint.Border)
57469
+ }
57470
+
57414
57471
  this.EnableNewIndex=false; //分时图是否使用最新的索引结构 (由外部chart容器传入)
57415
57472
  this.CorssCursorIndex; //分时图新版本的索引结构 (由外部chart容器传入)
57416
57473
 
@@ -57459,6 +57516,10 @@ function ChartCorssCursor()
57459
57516
  this.BorderColor=g_JSChartResource.CorssCursorBorderColor; //边框颜色
57460
57517
  this.XRangeBGColor=g_JSChartResource.CorssCursorXRangeBGColor;
57461
57518
  this.LineDash=g_JSChartResource.CorssCursorLineDash.slice(); //虚线
57519
+
57520
+
57521
+ this.CorssPointConfig.Center=CloneData(g_JSChartResource.CorssCursor.CorssPoint.Center);
57522
+ this.CorssPointConfig.Border=CloneData(g_JSChartResource.CorssCursor.CorssPoint.Border);
57462
57523
  }
57463
57524
 
57464
57525
  this.GetCloseYPoint=function(index)
@@ -57783,7 +57844,10 @@ function ChartCorssCursor()
57783
57844
 
57784
57845
  this.Canvas.stroke();
57785
57846
  this.Canvas.restore();
57786
-
57847
+
57848
+ this.Canvas.save();
57849
+ this.DrawCorssPoint(x,y);
57850
+ this.Canvas.restore();
57787
57851
  }
57788
57852
 
57789
57853
  var xValue=this.Frame.GetXData(x);
@@ -58645,6 +58709,30 @@ function ChartCorssCursor()
58645
58709
  }
58646
58710
  }
58647
58711
 
58712
+
58713
+ this.DrawCorssPoint=function(x,y)
58714
+ {
58715
+ var config=this.CorssPointConfig;
58716
+ if (!config.Enable) return;
58717
+
58718
+ this.Canvas.beginPath();
58719
+ this.Canvas.arc(x,y,config.Center.Radius,0,360,false);
58720
+ this.Canvas.closePath();
58721
+
58722
+ if (config.Center && config.Center.Color)
58723
+ {
58724
+ this.Canvas.fillStyle=config.Center.Color;
58725
+ this.Canvas.fill();
58726
+ }
58727
+
58728
+ if (config.Border && config.Border.Color)
58729
+ {
58730
+ this.Canvas.strokeStyle=config.Border.Color;
58731
+ if (IFrameSplitOperator.IsNumber(config.Border.Width)) this.Canvas.lineWidth=config.Border.Width;
58732
+ this.Canvas.stroke();
58733
+ }
58734
+ }
58735
+
58648
58736
  }
58649
58737
 
58650
58738
 
@@ -75388,7 +75476,9 @@ function JSChartResource()
75388
75476
  RightMargin: { Left:2, Right:2, Top:5, Bottom:3 },
75389
75477
 
75390
75478
  BottomText:{ Margin: { Left:4, Right:4, Top:0, Bottom:0 }, TextOffset:{X:4, Y:-1 } },
75391
- LeftText:{ Margin: { Left:4, Right:4, Top:0, Bottom:0 }, TextOffset:{X:4, Y:-1 } }
75479
+ LeftText:{ Margin: { Left:4, Right:4, Top:0, Bottom:0 }, TextOffset:{X:4, Y:-1 } },
75480
+
75481
+ CorssPoint:{ Center:{ Radius:5*GetDevicePixelRatio(), Color:"rgb(50,171,205)"}, Border:{ Color:'rgb(255,255,255)', Width:1*GetDevicePixelRatio() } }
75392
75482
  };
75393
75483
 
75394
75484
  this.LockBGColor = "rgb(220, 220, 220)"; //指标锁区域颜色
@@ -76827,6 +76917,26 @@ function JSChartResource()
76827
76917
  if (item.PenColor) this.CorssCursor.RightButton.PenColor=item.PenColor;
76828
76918
  if (item.Icon) this.CorssCursor.RightButton.Icon=item.Icon;
76829
76919
  }
76920
+
76921
+ if (style.CorssCursor && style.CorssCursor.CorssPoint)
76922
+ {
76923
+ var item=style.CorssCursor.CorssPoint;
76924
+ if (item.Center)
76925
+ {
76926
+ var subItem=item.Center;
76927
+ var subDest=this.CorssCursor.CorssPoint.Center;
76928
+ if (IFrameSplitOperator.IsNumber(subItem.Radius)) subDest.Radius=subItem.Radius;
76929
+ if (subItem.Color) subDest.Color=subItem.Color;
76930
+ }
76931
+
76932
+ if (item.Border)
76933
+ {
76934
+ var subItem=item.Border;
76935
+ var subDest=this.CorssCursor.CorssPoint.Border;
76936
+ if (IFrameSplitOperator.IsNumber(subItem.Width)) subDest.Width=subItem.Width;
76937
+ if (subItem.Color) subDest.Color=subItem.Color;
76938
+ }
76939
+ }
76830
76940
 
76831
76941
  if (style.KLine) this.KLine = style.KLine;
76832
76942
  if (style.VirtualKLine)
@@ -84847,11 +84957,13 @@ function KLineChartContainer(uielement,OffscreenElement, cacheElement)
84847
84957
  var bShowCorss=false; //十字光标十字线
84848
84958
  var bCorssDrawKLine=false;
84849
84959
  var bCorssDrawVaildTime=false;
84960
+ var bCorssDrawPoint=false;
84850
84961
  if (this.ChartCorssCursor)
84851
84962
  {
84852
84963
  bShowCorss=this.ChartCorssCursor.IsShowCorss;
84853
84964
  bCorssDrawKLine=this.ChartCorssCursor.IsOnlyDrawKLine && this.ChartCorssCursor.IsShowClose;
84854
84965
  bCorssDrawVaildTime=this.ChartCorssCursor.IsFixXLastTime;
84966
+ bCorssDrawPoint=this.ChartCorssCursor.CorssPointConfig.Enable;
84855
84967
  }
84856
84968
 
84857
84969
  var bPopMinuteChart=false;
@@ -85028,6 +85140,7 @@ function KLineChartContainer(uielement,OffscreenElement, cacheElement)
85028
85140
  { Name:"显示", Data:{ ID:JSCHART_MENU_ID.CMD_SHOW_CORSS_LINE_ID, Args:[!bShowCorss]}, Checked:bShowCorss },
85029
85141
  { Name:"显示在K线上", Data:{ ID:JSCHART_MENU_ID.CMD_CORSS_ON_KLINE_ID, Args:[!bCorssDrawKLine]}, Checked:bCorssDrawKLine },
85030
85142
  { Name:"画在有效X轴上",Data:{ ID:JSCHART_MENU_ID.CMD_CORSS_ON_VAILD_TIME_ID, Args:[!bCorssDrawVaildTime]}, Checked:bCorssDrawVaildTime },
85143
+ { Name:"画圆点",Data:{ ID:JSCHART_MENU_ID.CMD_CORSS_POINT_ID, Args:[!bCorssDrawPoint]}, Checked:bCorssDrawPoint },
85031
85144
  ]
85032
85145
  },
85033
85146
  {
@@ -89007,11 +89120,13 @@ function MinuteChartContainer(uielement,offscreenElement,cacheElement)
89007
89120
  var bShowCorss=false; //十字光标十字线
89008
89121
  var bCorssDrawCloseLine=false; //十字光标只能画在走势图价格线上
89009
89122
  var bCorssDrawVaildTime=false;
89123
+ var bCorssDrawPoint=false;
89010
89124
  if (this.ChartCorssCursor)
89011
89125
  {
89012
89126
  bShowCorss=this.ChartCorssCursor.IsShowCorss;
89013
89127
  bCorssDrawCloseLine=this.ChartCorssCursor.IsOnlyDrawMinute;
89014
89128
  bCorssDrawVaildTime=this.ChartCorssCursor.IsFixXLastTime;
89129
+ bCorssDrawPoint=this.ChartCorssCursor.CorssPointConfig.Enable;
89015
89130
  }
89016
89131
 
89017
89132
 
@@ -89096,6 +89211,7 @@ function MinuteChartContainer(uielement,offscreenElement,cacheElement)
89096
89211
  { Name:"显示", Data:{ ID:JSCHART_MENU_ID.CMD_SHOW_CORSS_LINE_ID, Args:[!bShowCorss]}, Checked:bShowCorss },
89097
89212
  { Name:"画在价格线上", Data:{ ID:JSCHART_MENU_ID.CMD_CORSS_ON_CLOSE_LINE_ID, Args:[!bCorssDrawCloseLine]}, Checked:bCorssDrawCloseLine },
89098
89213
  { Name:"画在有效X轴上",Data:{ ID:JSCHART_MENU_ID.CMD_CORSS_ON_VAILD_TIME_ID, Args:[!bCorssDrawVaildTime]}, Checked:bCorssDrawVaildTime },
89214
+ { Name:"画圆点",Data:{ ID:JSCHART_MENU_ID.CMD_CORSS_POINT_ID, Args:[!bCorssDrawPoint]}, Checked:bCorssDrawPoint },
89099
89215
  ]
89100
89216
  },
89101
89217
 
@@ -128532,7 +128648,9 @@ function GetBlackStyle()
128532
128648
  BGColor:'rgb(43,54,69)',
128533
128649
  PenColor:'rgb(255,255,255)',
128534
128650
  Icon: { Text:'\ue6a3', Color:'rgb(255,255,255)', Family:"iconfont", Size:18 }
128535
- }
128651
+ },
128652
+
128653
+ CorssPoint:{ Center:{ Color:"rgb(50,171,205)" }, Border:{ Color:'rgba(0,0,0,0.8)', Width:1*GetDevicePixelRatio() } }
128536
128654
  },
128537
128655
 
128538
128656
  //订单流配置
@@ -153263,7 +153381,7 @@ function HQChartScriptWorker()
153263
153381
 
153264
153382
 
153265
153383
 
153266
- var HQCHART_VERSION="1.1.14445";
153384
+ var HQCHART_VERSION="1.1.14451";
153267
153385
 
153268
153386
  function PrintHQChartVersion()
153269
153387
  {