2014-04-12 1 views
1

Я надеюсь, что кто-то может мне помочь. Я - любительский разработчик (в лучшем случае), который в основном пишет код, помогающий анализировать файлы журналов, и я борюсь с графикой.Графики WPF - Поворот ярлыков XAXIS

В приведенном ниже коде я просто беру любой DataTable (с правильно названными столбцами и типами данных) и создавая сложную диаграмму с помощью инструментария WPF. Мне очень тяжело вращать метки XAXIS.

Я просмотрел все эти ссылки и попытался интегрировать их в то, что я уже сделал, но ничего не работает, или я не совсем уверен, как интерпретировать эти ссылки. Может ли кто-нибудь объяснить мне, как повернуть мой XAXIS после просмотра того, как мой график создается?

Silverlight: How to change AxisLabelStyle in code behind?

http://blogs.msdn.com/b/delay/archive/2010/03/06/turn-your-head-and-check-out-this-post-how-to-easily-rotate-the-axis-labels-of-a-silverlight-wpf-toolkit-chart.aspx

Create style to rotate axis label in code behind

Вот мой код:

XAML:

<Window x:Class="gtseq_stats.MainWindow" 
     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
     Title="Main" Height="451" Width="685" xmlns:toolkit="http://schemas.microsoft.com/winfx/2006/xaml/presentation/toolkit" RenderTransform="{Binding StringFormat=\{0:g\}}"> 
    <Grid ForceCursor="True"> 
     <Grid.ColumnDefinitions> 
      <ColumnDefinition Width="552*" /> 
      <ColumnDefinition Width="142*" /> 
      <ColumnDefinition Width="Auto" /> 
      <ColumnDefinition Width="Auto" /> 
     </Grid.ColumnDefinitions> 
     <ComboBox Height="23" HorizontalAlignment="Left" Margin="2,2,0,0" Name="cbx_report_name" VerticalAlignment="Top" Width="320" DisplayMemberPath="report_name_alias" SelectedValuePath="report_data_id" SelectionChanged="cbx_report_name_SelectionChanged" /> 
     <toolkit:Chart Margin="10,31,12,12" Name="OutputChart" Grid.ColumnSpan="2" />   
     <Button Content="Button" Height="26" HorizontalAlignment="Left" Margin="350,2,0,0" Name="button1" VerticalAlignment="Top" Width="53" Click="button1_Click" FlowDirection="RightToLeft" /> 
    </Grid> 

</Window> 

И тогда мой C#:

public void BuildStackedChart(DataTable dtResults) 
    { 
     OutputChart.Series.Clear(); 
     var palette = OutputChart.Palette; 
     OutputChart.Palette = null; 
     OutputChart.Palette = palette; 

     Dictionary<string, int> dictYAxis = new Dictionary<string,int>(); 

     try 
     { 
      //Get a list of distinct Y axis and add them to a dictionary. This will be used later so we can assigne values to the proper dataValues. 
      var distinctYAxis = (from row in dtResults.AsEnumerable() 
           //orderby row.Field<string>("fix_line") ascending 
           select row.Field<string>("YAXIS")).Distinct(); 
      int i = 0; 
      foreach (var name in distinctYAxis) 
      { 
       dictYAxis.Add(name, i); 
       i++; 
      } 
     } 
     catch 
     { 
      MessageBox.Show("Couldn't Properly Load Data. The data must have only 3 columns: XAXIS-DateTime Data Type" + Environment.NewLine + "YAXIS-String Value" + Environment.NewLine + "PLOTVALUES-Number"); 
      return; 
     } 

     var dataValues = new List<List<SimpleDataValue>>(); 
     try 
     { 
      //Add a new entry for however many YAxis we have (No Data is used at this point are we aren't linking the #'s in the dictionary to the data elements here. 
      //However, we will use the dictorary to add the enteries and use the numbers to respresent the rows. 
      foreach(KeyValuePair<string, int> pair in dictYAxis) 
      { 
       dataValues.Add(new List<SimpleDataValue>()); 
      } 

      foreach (DataRow row in dtResults.Rows) // Loop over the rows. 
      { 
       dataValues[dictYAxis[row["YAXIS"].ToString()]].Add(new SimpleDataValue { DependentValue = Convert.ToDouble(row["PLOTVALUES"]), IndependentValue = Convert.ToDateTime(row["XAXIS"])}); 
      }    

     } 
     catch 
     { 
      dataValues.Clear(); 
     } 

     int i2 = 0; 
     var stackedSeries = Activator.CreateInstance(typeof(StackedColumnSeries)) as DefinitionSeries; 
     foreach (var values in dataValues) 
     { 
      var definition = new SeriesDefinition(); 
      definition.DependentValuePath = "DependentValue"; 
      definition.IndependentValuePath = "IndependentValue"; 
      definition.Title = dictYAxis.FirstOrDefault(x => x.Value == i2).Key; ; 
      definition.ItemsSource = values;     
      stackedSeries.SeriesDefinitions.Add(definition); 
      i2++; 
     } 
     OutputChart.Series.Add(stackedSeries); 
    } 
+1

Вы хотите повернуть текстовые значения оси х? – Sajeetharan

+0

Да. Я пытаюсь повернуть текстовые значения оси x. – user2786756

+0

Пожалуйста, помогите. Я просто попробовал этот RotateTransform rotateTransform1 = новый RotateTransform (-45); OutputChart.RenderTransform = rotateTransform1 ;, но теперь график тренда повернут: – user2786756

ответ

0

Проверить этот пост [How to: Easily rotate the axis labels of a Silverlight/WPF Toolkit chart]

<charting:ColumnSeries.IndependentAxis> 
       <charting:CategoryAxis 
        Orientation="X"> 
        <charting:CategoryAxis.AxisLabelStyle> 
         <Style TargetType="charting:AxisLabel"> 
          <Setter Property="Template"> 
           <Setter.Value> 
            <ControlTemplate TargetType="charting:AxisLabel"> 
             <layout:LayoutTransformer> 
              <layout:LayoutTransformer.LayoutTransform> 
               <RotateTransform Angle="-60"/> 
              </layout:LayoutTransformer.LayoutTransform> 
              <TextBlock Text="{TemplateBinding FormattedContent}"/> 
             </layout:LayoutTransformer> 
            </ControlTemplate> 
           </Setter.Value> 
          </Setter> 
         </Style> 
        </charting:CategoryAxis.AxisLabelStyle> 
       </charting:CategoryAxis> 
      </charting:ColumnSeries.IndependentAxis>