Click here to Skip to main content
15,884,537 members
Articles / Desktop Programming / WPF

OpenWPFChart: assembling charts from components: Part I - Parts

Rate me:
Please Sign up or sign in to vote.
4.29/5 (17 votes)
19 Mar 2009CPOL14 min read 81.7K   4K   81  
Provides the component model along with base components to assemble charts.
<!--
OpenWPFChart library WellLogChart control default style.
Copyright Oleg V. Polikarpotchkin 2008-2009
-->
<!--revision $Id: WellLogChart.Generic.xaml 18093 2009-03-16 04:15:06Z unknown $-->
<ResourceDictionary
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
	xmlns:sys="clr-namespace:System;assembly=mscorlib"
    xmlns:parts="clr-namespace:OpenWPFChart.Parts;assembly=OpenWPFChart.Parts"
    xmlns:local="clr-namespace:OpenWPFChart.Controls">
	
	<!-- WellLogChart Control Style -->
	<Style TargetType="{x:Type local:WellLogChart}">
		<Style.Resources>
			<!-- Curve templates -->
			<DataTemplate x:Key="polylineTemplate">
				<parts:PolylineSampledCurve ItemDataView="{Binding}"
					ToolTip="{Binding ItemData.ItemName}" 
					ContextMenu="{Binding Path=ContextMenu, 
						RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type local:WellLogChart}}}"/>
			</DataTemplate>
			<DataTemplate x:Key="bezierTemplate">
				<parts:BezierSampledCurve ItemDataView="{Binding}"
					ToolTip="{Binding ItemData.ItemName}" 
					ContextMenu="{Binding Path=ContextMenu, 
						RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type local:WellLogChart}}}"/>
			</DataTemplate>
			<DataTemplate x:Key="splineTemplate">
				<parts:SplineSampledCurve ItemDataView="{Binding}"
					ToolTip="{Binding ItemData.ItemName}" 
					ContextMenu="{Binding Path=ContextMenu, 
						RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type local:WellLogChart}}}"/>
			</DataTemplate>

			<!-- Chart Items Template Selector -->
			<parts:GenericDataTemplateSelector x:Key="chartItemsTemplateSelector">
				<parts:GenericDataTemplateSelectorItem
					PropertyName="VisualCue" 
					Value="{x:Type parts:PolylineSampledCurve}"
					Template="{StaticResource polylineTemplate}"
					TemplatedType="{x:Type parts:SampledCurveDataView}"
					Description="Polyline Sampled Curve"/>
				<parts:GenericDataTemplateSelectorItem
					PropertyName="VisualCue" 
					Value="{x:Type parts:BezierSampledCurve}"
					Template="{StaticResource bezierTemplate}"
					TemplatedType="{x:Type parts:SampledCurveDataView}"
					Description="Bezier Sampled Curve"/>
				<parts:GenericDataTemplateSelectorItem
					PropertyName="VisualCue" 
					Value="{x:Type parts:SplineSampledCurve}"
					Template="{StaticResource splineTemplate}"
					TemplatedType="{x:Type parts:SampledCurveDataView}"
					Description="Spline Sampled Curve"/>
			</parts:GenericDataTemplateSelector>

			<!-- WellLog Header MinMaxValueConverter -->
			<local:EnumerableMinMaxValueConverter x:Key="minMaxValueConverter"/>
			
			<!-- WellLog Header Template -->
			<DataTemplate x:Key="SampledCurveHeaderTemplate">
				<Border BorderThickness="1" BorderBrush="Bisque">
					<Grid HorizontalAlignment="Stretch" ShowGridLines="False">
						<Grid.RowDefinitions>
							<RowDefinition Height="Auto"/>
							<RowDefinition Height="Auto"/>
						</Grid.RowDefinitions>
						<Grid.ColumnDefinitions>
							<ColumnDefinition Width="Auto" SharedSizeGroup="ItemName"/>
							<ColumnDefinition Width="Auto" SharedSizeGroup="MinValue"/>
							<ColumnDefinition/>
							<ColumnDefinition Width="Auto" SharedSizeGroup="MaxValue"/>
						</Grid.ColumnDefinitions>

						<TextBlock Text="{Binding Path=ItemData.ItemName}" VerticalAlignment="Center"/>
						<TextBlock Grid.Column="1" VerticalAlignment="Center" Margin="3,0,0,0"
							   Text="{Binding Path=ItemData.Points, Converter={StaticResource minMaxValueConverter}}"/>
						<Image Grid.Column="2" Stretch="None" HorizontalAlignment="Center"
						   VerticalAlignment="Center">
							<Image.Source>
								<DrawingImage>
									<DrawingImage.Drawing>
										<Binding Path="PointMarker"/>
									</DrawingImage.Drawing>
								</DrawingImage>
							</Image.Source>
						</Image>
						<TextBlock Grid.Column="3" VerticalAlignment="Center"
							Text="{Binding Path=ItemData.Points, Converter={StaticResource minMaxValueConverter}, ConverterParameter=true}"/>
						<Rectangle Grid.Row="1" Grid.ColumnSpan="4" 
							Fill="{Binding Path=Pen.Brush}" Height="2"
							VerticalAlignment="Center" HorizontalAlignment="Stretch"
							Margin="0,5,0,5"/>
					</Grid>
				</Border>
			</DataTemplate>
			
			<local:ItemCountToVisibilityConverter x:Key="itemCountToVisibility"/>
		</Style.Resources>
		
		<!-- Base ListBox ItemsPanel Template -->
		<Setter Property="ItemsPanel">
			<Setter.Value>
				<ItemsPanelTemplate>
					<Canvas />
				</ItemsPanelTemplate>
			</Setter.Value>
		</Setter>

		<!-- Base ListBox ItemContainer Style -->
		<Setter Property="ItemContainerStyle">
			<Setter.Value>
				<Style TargetType="{x:Type ListBoxItem}">
					<Setter Property="Template">
						<Setter.Value>
							<ControlTemplate TargetType="{x:Type ListBoxItem}">
								<ContentPresenter x:Name="ContentHost"/>
								<ControlTemplate.Triggers>
									<Trigger Property="Selector.IsSelected" Value="True">
										<Setter TargetName="ContentHost" Property="BitmapEffect">
											<Setter.Value>
												<DropShadowBitmapEffect Color="Black" Direction="320" 
																		ShadowDepth="5" Softness="0.2" 
																		Opacity="0.8"/>
											</Setter.Value>
										</Setter>
									</Trigger>
								</ControlTemplate.Triggers>
							</ControlTemplate>
						</Setter.Value>
					</Setter>
				</Style>
			</Setter.Value>
		</Setter>

		<!-- Base ListBox ItemTemplateSelector -->
		<Setter Property="ItemTemplateSelector" Value="{StaticResource chartItemsTemplateSelector}"/>

		<!-- WellLogChart Control Template -->
		<Setter Property="Template">
			<Setter.Value>
				<ControlTemplate TargetType="{x:Type local:WellLogChart}">
					<Border Name="Bd"
							BorderThickness="{TemplateBinding Border.BorderThickness}" 
							BorderBrush="{TemplateBinding Border.BorderBrush}" 
							Background="{TemplateBinding Panel.Background}" 
							Padding="1,1,1,1" 
							SnapsToDevicePixels="True">
						<ScrollViewer
								HorizontalScrollBarVisibility="Auto" VerticalScrollBarVisibility="Auto"
								Padding="{TemplateBinding Control.Padding}" Focusable="False">
							<Grid ShowGridLines="False"
								  Visibility="{Binding RelativeSource={RelativeSource TemplatedParent}, 
									Path=Items.Count, Converter={StaticResource itemCountToVisibility}}">
								<Grid.RowDefinitions>
									<RowDefinition Height="Auto"/>
									<RowDefinition Height="Auto"/>
								</Grid.RowDefinitions>
								<Grid.ColumnDefinitions>
									<ColumnDefinition/>
									<ColumnDefinition/>
								</Grid.ColumnDefinitions>

								<!-- WellLogHeader - Horizontal Top WellLog axes -->
								<ListBox Grid.Column="1" VerticalAlignment="Top"
									ItemsSource="{Binding RelativeSource={RelativeSource TemplatedParent}, Path=ItemsSource}"
									ItemTemplate="{StaticResource SampledCurveHeaderTemplate}"
									SelectedItem="{Binding RelativeSource={RelativeSource TemplatedParent}, Path=SelectedItem}"
									HorizontalContentAlignment="Stretch"
									Grid.IsSharedSizeScope="True"/>

								<!-- Vertical Left Depth axis -->
								<Grid Grid.Row="1">
									<Grid.RowDefinitions>
										<RowDefinition/>
										<RowDefinition/>
									</Grid.RowDefinitions>

									<parts:LinearAxis x:Name="depthAxis" 
										AxisScale="{Binding RelativeSource={RelativeSource TemplatedParent}, 
											Path=SelectedItem.HorizontalScale}"/>
									<TextBlock Grid.Row="1" HorizontalAlignment="Center" 
										Text="{TemplateBinding DepthAxisTitle}"
										Foreground="{Binding RelativeSource={RelativeSource TemplatedParent}, 
											Path=(parts:Axis.Pen).Brush}"/>

									<Grid.LayoutTransform>
										<RotateTransform Angle="90"/>
									</Grid.LayoutTransform>
								</Grid>

								<!-- Chart area -->
								<Grid Grid.Row="1" Grid.Column="1">
									<!--Coordinate grids-->
									<parts:Grid
										HorizontalScale="{Binding RelativeSource={RelativeSource TemplatedParent}, 
											Path=SelectedItem.VerticalScale}"
										VerticalScale="{Binding RelativeSource={RelativeSource TemplatedParent}, 
											Path=SelectedItem.HorizontalScale}"
										GridVisibility="{TemplateBinding VerticalGridVisibility}"
									/>
									<parts:Grid Orientation="Horizontal"
										HorizontalScale="{Binding RelativeSource={RelativeSource TemplatedParent}, 
											Path=SelectedItem.VerticalScale}"
										VerticalScale="{Binding RelativeSource={RelativeSource TemplatedParent}, 
											Path=SelectedItem.HorizontalScale}"
										GridVisibility="{TemplateBinding HorizontalGridVisibility}"
									/>
									<ItemsPresenter SnapsToDevicePixels="{TemplateBinding UIElement.SnapsToDevicePixels}" />
								</Grid>
							</Grid>
						</ScrollViewer>
					</Border>
				</ControlTemplate>
			</Setter.Value>
		</Setter>
	</Style>
</ResourceDictionary>

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


Written By
Team Leader
Russian Federation Russian Federation
This member has not yet provided a Biography. Assume it's interesting and varied, and probably something to do with programming.

Comments and Discussions