0

チャートコントロールを含むSilverlightプロジェクトを開発しています。

私はチャートコントロールを使用しており、そのシリーズでは、2つのMenuItemsを持つ左クリックコンテキストメニューを実装しました。「拡張」と「ドリル」。

public class WebChart : Chart
{
     ContextMenu ChartItemDataMenu;

     public WebChart()
        : base()
    {
        this.Loaded += new RoutedEventHandler(WebChart_Loaded);
    }

    private void WebChart_Loaded(object sender, RoutedEventArgs e)
    {
        MenuItem expand = new MenuItem();
        expand.Click += new RoutedEventHandler(OnExpand_Click);
        ToolTipService.SetToolTip(expand, "Expand");

        MenuItem drill = new MenuItem();
        drill.Click += new RoutedEventHandler(OnDrill_Click);
        ToolTipService.SetToolTip(drill, "Drill");

        ChartItemDataMenu = new ContextMenu();

        ChartItemDataMenu.Items.Add(expand);
        ChartItemDataMenu.Items.Add(drill);

        this.DataItemMouseLeftButtonDown += 
            new EventHandler<DataItemMouseEventArgs>(ExtendedXamWebChart_DataItemMouseLeftButtonDown);

        this.MouseRightButtonDown -= (s, eventArgs) => { eventArgs.Handled = true; };
        this.MouseRightButtonDown += (s, eventArgs) => { eventArgs.Handled = true; };
    }

    private void ExtendedXamWebChart_DataItemMouseLeftButtonDown(object sender, DataItemMouseEventArgs e)
    { 
        ChartItemDataMenu.IsOpen = true;
    }

私が個別のクリックイベントを宣言した両方のメニュー項目について、それらを登録して発生させました。次に、XAMLのこれらのイベントをビューモデルのICommandプロパティに結合しました。

    public delegate void WebChartEventHandler(object sender, DataItemMouseEventArgs e, DataPoint dp, qcPoint qp);

    public event WebChartEventHandler ExpandClickEvent;
    public event WebChartEventHandler DrillClickEvent;

    private void OnDrill_Click(object sender, RoutedEventArgs e)
    {
        if (currentDataItemMouseEventArgs == null)
            currentDataItemMouseEventArgs = new DataItemMouseEventArgs();
        if (DrillClickEvent != null)
        { DrillClickEvent(sender, currentDataItemMouseEventArgs, SelectedDataPoint, CurrentSelectedPoint); }
    }

    private void OnExpand_Click(object sender, RoutedEventArgs e)
    {
        if (currentDataItemMouseEventArgs == null)
            currentDataItemMouseEventArgs = new DataItemMouseEventArgs();
        if (ExpandClickEvent != null)
        { ExpandClickEvent(sender, currentDataItemMouseEventArgs, SelectedDataPoint, CurrentSelectedPoint); }
    }
}

しかし、コードをデバッグすると、「ExpandClickEvent」と「DrillClickEvent」がnullとして表示されます。これは、誰もそれを聞いていないためです。

このWebChartコントロールをChartBaseControlという名前の別のユーザーコントロールで使用しています。このユーザーコントロールは、GraphControlという名前の別のユーザーコントロールで使用されています。DataContextは適切にセットアップされています。ViewModelGraphControlという名前のViewModelを作成しました。

足りないものがあると思います。問題の世話をしてください。

編集されたコンテンツ:XAML:

<extnchart:WebChart Grid.Row="0" x:Name="CTRLWebChart" VerticalAlignment="Stretch" 
                                           Margin="0,-23,0,0" IsDrillEnable="True" 
                                           local:AxisTitleSettings.XAxisTitle="X-Axis" 
                                           local:AxisTitleSettings.YAxisTitle="Y-Axis" 
ChartSeriesCollection="{Binding WebChartSource, Mode=TwoWay}">
                <i:Interaction.Triggers>
                    <i:EventTrigger EventName="DrillClickEvent">
                        <command:EventToCommand Command="{Binding OnDrill_Click}"     PassEventArgsToCommand="True"/>
                    </i:EventTrigger>
                    <i:EventTrigger EventName="ExpandClickEvent">
                        <command:EventToCommand Command="{Binding OnExpand_Click}"     PassEventArgsToCommand="True"/>
                    </i:EventTrigger>
                </i:Interaction.Triggers>
                <extnchart:ExtendedXamWebChart.Axes>
                    <igWebChart:Axis AxisType="PrimaryX">
                        <igWebChart:Axis.Label>
                            <igWebChart:LabelGroup DistanceFromAxis="2"/>
                        </igWebChart:Axis.Label>
                    </igWebChart:Axis>
                    <igWebChart:Axis AxisType="PrimaryY">
                        <igWebChart:Axis.Label>
                            <igWebChart:LabelGroup FontSize="11"/>
                        </igWebChart:Axis.Label>
                    </igWebChart:Axis>
                </extnchart:ExtendedXamWebChart.Axes>
            </extnchart:ExtendedXamWebChart>
4

1 に答える 1

0

質問に対する答えを見つけました。

カスタムイベントハンドラーを使用する代わりに、イベントがページ間でルーティングされるため、ルーティングイベントハンドラーを使用しました。

また、カスタムパラメータをViewModelに送信するために、ExtendedRoutedEventArgsという名前の新しいクラスを作成し、RoutedEventArgsクラスから継承して、アクセスしたいフィールドとプロパティを作成しました。

    public class ExtendedRoutedEventArgs : RoutedEventArgs
    {
        public ExtendedRoutedEventArgs()
            : base()
        {

        }
        private DataItemMouseEventArgs currentDataItemMouseEventArgs;

        public DataItemMouseEventArgs CurrentDataItemMouseEventArgs
        {
            get { return currentDataItemMouseEventArgs; }
            set { currentDataItemMouseEventArgs = value; }
        }

        private DataPoint selectedDataPointe;

        public DataPoint SelectedDataPointe
        {
            get { return selectedDataPointe; }
            set { selectedDataPointe = value; }
        }

        private qcPoint currentSelectedQcPoint;

        public qcPoint CurrentSelectedQcPoint
        {
            get { return currentSelectedQcPoint; }
            set { currentSelectedQcPoint = value; }
        }
    }

次に、次の方法でイベントを発生させます。

public class WebChart : Chart
{
    void OnDrill_Click(object sender, RoutedEventArgs e)
    {
        if (currentDataItemMouseEventArgs == null)

            currentDataItemMouseEventArgs = new DataItemMouseEventArgs();
        if (DrillClickEvent != null)
        {
            DrillClickEvent(sender, new ExtendedRoutedEventArgs
            {
                CurrentDataItemMouseEventArgs = currentDataItemMouseEventArgs,
                SelectedDataPointe = SelectedDataPointe,
                CurrentSelectedQcPoint = CurrentSelectedQcPoint
            });
        }
    }
}
于 2011-10-17T04:26:37.630 に答える