2

我遇到了一个奇怪的要求。

当用户单击图表区域时,我需要从图表中获取 X 轴值。

我知道我们可以为图表分配一个宏。因此,可以为图表创建事件。但不知道如何进一步进行。

请问有什么想法吗?

谢谢。

4

1 回答 1

5

如果您的图表在图表表中,那么您可以右键单击图表表选项卡,选择“查看代码”并将以下内容粘贴到其代码模块中(见下面的截图)

Option Explicit

Private Sub Chart_Select(ByVal ElementID As Long, ByVal Arg1 As Long, ByVal Arg2 As Long)
    Select Case ElementID
    Case xlSeries
       If Arg2 > 0 Then
           MsgBox "Series " & Arg1 & vbCr & "Point " & Arg2
       End If
    Case Else
       MsgBox Arg1 & vbCr & Arg2
    End Select
End Sub

在此处输入图像描述

如果您的图表嵌入在工作表中,那么您将不得不使用WithEvents@brettdj 已在此处介绍的内容

跟进

这是你正在尝试的吗?

Private Sub Chart_Select(ByVal ElementID As Long, ByVal Arg1 As Long, ByVal Arg2 As Long)
    Select Case ElementID
    Case xlSeries
        If Arg2 > 0 Then
            x = ActiveChart.SeriesCollection(Arg1).XValues
            For i = LBound(x) To UBound(x)
                If i = Arg2 Then
                    MsgBox "Point :" & i & "and X Value = " & x(i)
                    Exit For
                End If
            Next i
       End If
    End Select
End Sub

在此处输入图像描述

于 2013-03-29T13:47:53.057 回答