@@ -577,6 +577,16 @@ function hover(gd, evt, subplot) {
577
577
container : fullLayout . _hoverlayer ,
578
578
outerContainer : fullLayout . _paperdiv
579
579
} ;
580
+
581
+ if ( gd . _context . showDroplines ) {
582
+ var droplineOpts = {
583
+ hovermode : hovermode ,
584
+ container : fullLayout . _hoverlayer ,
585
+ outerContainer : fullLayout . _paperdiv
586
+ } ;
587
+ createDroplines ( hoverData , droplineOpts ) ;
588
+ }
589
+
580
590
var hoverLabels = createHoverText ( hoverData , labelOpts ) ;
581
591
582
592
hoverAvoidOverlaps ( hoverData , rotateLabels ? 'xa' : 'ya' ) ;
@@ -818,8 +828,41 @@ fx.loneUnhover = function(containerOrSelection) {
818
828
d3 . select ( containerOrSelection ) ;
819
829
820
830
selection . selectAll ( 'g.hovertext' ) . remove ( ) ;
831
+ selection . selectAll ( 'line.dropline' ) . remove ( ) ;
821
832
} ;
822
833
834
+ function createDroplines ( hoverData , opts ) {
835
+ var hovermode = opts . hovermode ,
836
+ container = opts . container ;
837
+
838
+ if ( hovermode !== 'closest' ) return ;
839
+ var c0 = hoverData [ 0 ] ;
840
+ var x = ( c0 . x0 + c0 . x1 ) / 2 ;
841
+ var y = ( c0 . y0 + c0 . y1 ) / 2 ;
842
+ var xOffset = c0 . xa . _offset ;
843
+ var yOffset = c0 . ya . _offset ;
844
+ container . selectAll ( 'line.dropline' ) . remove ( ) ;
845
+ container . append ( 'line' )
846
+ . attr ( 'x1' , xOffset + ( c0 . ya . side === 'right' ? c0 . xa . _length : 0 ) )
847
+ . attr ( 'x2' , xOffset + x )
848
+ . attr ( 'y1' , yOffset + y )
849
+ . attr ( 'y2' , yOffset + y )
850
+ . attr ( 'stroke-width' , 3 )
851
+ . attr ( 'stroke' , c0 . color )
852
+ . attr ( 'stroke-dasharray' , '5,5' )
853
+ . attr ( 'class' , 'dropline' ) ;
854
+
855
+ container . append ( 'line' )
856
+ . attr ( 'x1' , xOffset + x )
857
+ . attr ( 'x2' , xOffset + x )
858
+ . attr ( 'y1' , yOffset + y )
859
+ . attr ( 'y2' , yOffset + c0 . ya . _length )
860
+ . attr ( 'stroke-width' , 3 )
861
+ . attr ( 'stroke' , c0 . color )
862
+ . attr ( 'stroke-dasharray' , '5,5' )
863
+ . attr ( 'class' , 'dropline' ) ;
864
+ }
865
+
823
866
function createHoverText ( hoverData , opts ) {
824
867
var hovermode = opts . hovermode ,
825
868
rotateLabels = opts . rotateLabels ,
0 commit comments