新手用WPF山寨QQ管家7.6(三)

因爲一直忙工做,沒有更新完博客,更可恨的是...在清理資料的時候不當心刪除了以前本身作的各類效果的DEMO....好在項目中用到了大部分,也算有所保留,之後可不敢隨便刪東西了....太可怕了!html

新手用WPF山寨QQ管家7.6(一) 中畫的QQ管家界面畢竟不能直接用在項目中,進行了修改(主要體如今圖標圖片上),最終項目效果圖以下:ide

統計圖使用的Visifire控件,風向圖以前我作的是黑色的,不太和諧,因此從新讓美工設計後,我懶得重繪了,底盤直接用圖片,指針本身畫了一個,至於換膚功能也保留了,只不過加入兩個純色的背景,一個藍色一個綠色,還添加了一個相似金山毒霸裏的監測界面:this

因爲我把本身作的DEMO刪除了,這裏給出這個界面樣式的代碼吧....spa

 <Grid>
        <Grid.RowDefinitions>
            <RowDefinition/>
            <RowDefinition Height="25"/>
        </Grid.RowDefinitions>
        <local:NavigationPanel x:Name="NavigationPanel" Orientation="Horizontal" VerticalAlignment="Top">
            <Grid x:Name="grid1">
                <Path Margin="117,428,0,0" HorizontalAlignment="Left" Data="M184,208 C184,280 184,280.0625 184,280.0625" Stretch="Fill" Stroke="#FFA3A3A3" Width="1">
                    <Path.Effect>
                        <DropShadowEffect BlurRadius="3" ShadowDepth="1" Direction="175" Opacity="0.795"/>
                    </Path.Effect>
                </Path>
                <TabControl TabStripPlacement="Left" BorderThickness="0" Background="Transparent">
                    <TabItem Height="107" Style="{StaticResource VerticalTabItem1}" Width="116">
                        <Grid>
                            <Frame Source="InstrumentParam\Instrument1.xaml" NavigationUIVisibility="Hidden" Margin="0,0,5,0" Background="Transparent"/>
                        </Grid>
                    </TabItem>
                    <TabItem Height="107" Style="{StaticResource VerticalTabItem2}" Width="116">
                        <Grid>
                            <Frame Source="InstrumentParam\Instrument2.xaml" NavigationUIVisibility="Hidden" Margin="0,0,5,0" Background="Transparent"/>
                        </Grid>
                    </TabItem>
                    <TabItem Height="107" Style="{StaticResource VerticalTabItem3}" Width="116"/>
                    <TabItem Height="107" Style="{StaticResource VerticalTabItem4}" Width="116"/>
                </TabControl>
            </Grid>
            <Grid x:Name="grid2">
                <Path Margin="117,321,0,0" HorizontalAlignment="Left" Data="M184,208 C184,280 184,280.0625 184,280.0625" Stretch="Fill" Stroke="#FFA3A3A3" Width="1">
                    <Path.Effect>
                        <DropShadowEffect BlurRadius="3" ShadowDepth="1" Direction="175" Opacity="0.795"/>
                    </Path.Effect>
                </Path>
                <TabControl TabStripPlacement="Left" BorderThickness="0" Background="Transparent">
                    <TabItem Height="107" Style="{StaticResource VerticalTabItem5}" Width="116">
                        <Grid>
                            <Frame Source="InstrumentParam\Instrument5.xaml" NavigationUIVisibility="Hidden" Margin="0,0,5,0" Background="Transparent"/>
                        </Grid>
                    </TabItem>
                    <TabItem Height="107" Style="{StaticResource VerticalTabItem6}" Width="116"/>
                    <TabItem Height="107" Style="{StaticResource VerticalTabItem7}" Width="116"/>
                </TabControl>
            </Grid>
        </local:NavigationPanel>
        <Grid Grid.Row="1"  Height="25"  >
            <Grid.Background>
                <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                    <GradientStop Color="#FFB7B7B7" Offset="0" />
                    <GradientStop Color="#FFF8FAFB" Offset="0.07" />
                </LinearGradientBrush>
            </Grid.Background>
            <StackPanel Orientation="Horizontal" HorizontalAlignment="Center">
                <Button  Height="18" Style="{StaticResource ChangePanelButtonStyle}" Width="18" HorizontalAlignment="Left" x:Name="btnLeft" 
                                IsEnabled="{Binding ElementName=NavigationPanel, Path=PreviousIsValid, Mode=OneWay}" Click="btnLeft_Click"/>
                <Border Width="20"/>
                <Button  Height="18" Style="{StaticResource ChangePanelButtonStyle}" Width="18" HorizontalAlignment="Left" x:Name="btnRight" 
                                IsEnabled="{Binding ElementName=NavigationPanel, Path=NextIsValid, Mode=OneWay}"  Click="btnRight_Click"/>
            </StackPanel>
        </Grid>
    </Grid>
代碼

樣式我仍是老辦法沒有作到一個樣式統一,結果就多少個TAB多了多少個樣式,我已經找到簡單辦法了,不過一直忙的沒去修改,你們本身用獲得本身修改設計

<Style x:Key="VerticalTabItem1" TargetType="{x:Type TabItem}">
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type TabItem}">
                    <ControlTemplate.Resources>
                        <Storyboard x:Key="mouseover">
                            <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.Opacity)" Storyboard.TargetName="stackPanel">
                                <EasingDoubleKeyFrame KeyTime="0" Value="1"/>
                            </DoubleAnimationUsingKeyFrames>
                        </Storyboard>
                        <Storyboard x:Key="Selected">
                            <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.Opacity)" Storyboard.TargetName="stackPanel">
                                <EasingDoubleKeyFrame KeyTime="0" Value="1"/>
                            </DoubleAnimationUsingKeyFrames>
                            <ObjectAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.Visibility)" Storyboard.TargetName="rectangle">
                                <DiscreteObjectKeyFrame KeyTime="0" Value="{x:Static Visibility.Visible}"/>
                            </ObjectAnimationUsingKeyFrames>
                            <ObjectAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.Visibility)" Storyboard.TargetName="border">
                                <DiscreteObjectKeyFrame KeyTime="0" Value="{x:Static Visibility.Hidden}"/>
                            </ObjectAnimationUsingKeyFrames>
                            <ObjectAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.Visibility)" Storyboard.TargetName="path">
                                <DiscreteObjectKeyFrame KeyTime="0" Value="{x:Static Visibility.Visible}"/>
                            </ObjectAnimationUsingKeyFrames>
                        </Storyboard>
                    </ControlTemplate.Resources>
                    <Grid>
                        <Grid.ColumnDefinitions>
                            <ColumnDefinition Width="5"/>
                            <ColumnDefinition Width="*"/>
                            <ColumnDefinition Width="8"/>
                        </Grid.ColumnDefinitions>
                        <Grid.RowDefinitions>
                            <RowDefinition Height="*"/>
                            <RowDefinition Height="2"/>
                        </Grid.RowDefinitions>
                        <Rectangle x:Name="rectangle" Width="5" Visibility="Hidden" >
                            <Rectangle.Fill>
                                <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                                    <GradientStop Color="#FF21C8FF" Offset="0"/>
                                    <GradientStop Color="#FF0064A3" Offset="1"/>
                                    <GradientStop Color="#FF0093CF" Offset="0.554"/>
                                    <GradientStop Color="#FF00A7E2" Offset="0.295"/>
                                    <GradientStop Color="#FF0EB1E7" Offset="0.147"/>
                                </LinearGradientBrush>
                            </Rectangle.Fill>
                        </Rectangle>
                        <StackPanel x:Name="stackPanel" Grid.Column="1" Margin="5,0,0,0" HorizontalAlignment="Center" VerticalAlignment="Center" Opacity="0.3">
                            <Image Source="../Resource/Image/Instrument1.png" Width="60" Height="60" />
                            <TextBlock Text="API 100e" HorizontalAlignment="Center" FontSize="15" Foreground="#FF21A1D5"/>
                        </StackPanel>
                        <Border Grid.Row="1" Grid.ColumnSpan="3" Height="2" BorderThickness="1">
                            <Border.BorderBrush>
                                <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                                    <GradientStop Color="#FFB6B6B6"/>
                                    <GradientStop Color="White" Offset="0.771"/>
                                    <GradientStop Color="#FFCCCCCC" Offset="0.209"/>
                                    <GradientStop Color="#FFE4E4E4" Offset="0.45"/>
                                    <GradientStop Color="#FFF7F5F5" Offset="0.562"/>
                                </LinearGradientBrush>
                            </Border.BorderBrush>
                        </Border>
                        <Path x:Name="path" Visibility="Hidden" Data="M400,280 C400,320 400,320 400,320 392,328 392,328 392,328 400,336 400,336 400,336 400,376 400,376 400,376" Grid.Column="2" Grid.RowSpan="2" Stretch="Fill" Width="8" Stroke="#FFA3A3A3" Margin="0,-0.5">
                            <Path.Effect>
                                <DropShadowEffect BlurRadius="3" ShadowDepth="1" Direction="175" Opacity="0.795"/>
                            </Path.Effect>
                        </Path>
                        <Path x:Name="border" Grid.Column="2" Grid.RowSpan="2" Margin="7,-0.5,0,-0.5" Data="M184,208 C184,280 184,280.0625 184,280.0625" Stretch="Fill" Stroke="#FFA3A3A3" Width="1">
                            <Path.Effect>
                                <DropShadowEffect BlurRadius="3" ShadowDepth="1" Direction="175" Opacity="0.795"/>
                            </Path.Effect>
                        </Path>
                    </Grid>
                    <ControlTemplate.Triggers>
                        <Trigger Property="Selector.IsSelected" Value="True">
                            <Trigger.ExitActions>
                                <RemoveStoryboard BeginStoryboardName="Selected_BeginStoryboard"/>
                            </Trigger.ExitActions>
                            <Trigger.EnterActions>
                                <BeginStoryboard x:Name="Selected_BeginStoryboard" Storyboard="{StaticResource Selected}"/>
                            </Trigger.EnterActions>
                        </Trigger>
                        <Trigger Property="IsMouseOver" Value="True">
                            <Trigger.ExitActions>
                                <RemoveStoryboard BeginStoryboardName="mouseover_BeginStoryboard"/>
                            </Trigger.ExitActions>
                            <Trigger.EnterActions>
                                <BeginStoryboard x:Name="mouseover_BeginStoryboard" Storyboard="{StaticResource mouseover}"/>
                            </Trigger.EnterActions>
                        </Trigger>
                    </ControlTemplate.Triggers>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
        <Setter Property="FontSize" Value="15"/>
        <Setter Property="Foreground" Value="#FF41C2D3"/>
    </Style>
View Code

頁面切換我是從網上找到的一個DEMO直接拿來用了,忘了做者是誰了,一年前找的3d

  public class NavigationPanel : StackPanel
    {
        public event EventHandler AnimationComplte;
        private static double COUNT_OF_PAGE;
        private TranslateTransform NavigationPanelTranslateTransform;


        private static readonly TimeSpan DURATION = TimeSpan.FromMilliseconds(250);

        public NavigationPanel()
            : base()
        {
            this.Orientation = Orientation.Horizontal;


            NavigationPanelTranslateTransform = new TranslateTransform();

            this.Loaded += new RoutedEventHandler(NavigationPanel_Loaded);
        }

        void NavigationPanel_Loaded(object sender, RoutedEventArgs e)
        {
            COUNT_OF_PAGE = this.Children.Count;
            CurrentIndex = 0;
            foreach (FrameworkElement fe in this.Children)
            {
                fe.RenderTransform = NavigationPanelTranslateTransform;
            }
        }

        public void Next()
        {
            AnimationChildren(true);
        }

        public void Previous()
        {
            AnimationChildren(false);
        }


        private bool ValidateNext()
        {
            return CurrentIndex < (COUNT_OF_PAGE - 1) && CurrentIndex >= 0;
        }


        private bool ValidatePrevious()
        {
            return CurrentIndex <= (COUNT_OF_PAGE - 1) && CurrentIndex > 0;
        }

        private bool ValidateCurrentIndex()
        {
            if (CurrentIndex > -1 && CurrentIndex < this.Children.Count)
            {
                return true;
            }

            return false;
        }

        private void AnimationChildren(bool forward)
        {
            double currentTranX = NavigationPanelTranslateTransform.X;
            double nextTranX = currentTranX;
            if (forward)
            {
                if (ValidateCurrentIndex())
                {
                    nextTranX -= (this.Children[CurrentIndex] as FrameworkElement).ActualWidth;
                }

            }
            else
            {
                if (ValidateCurrentIndex())
                {
                    nextTranX += (this.Children[CurrentIndex] as FrameworkElement).ActualWidth;
                }

            }

            DoubleAnimation da = new DoubleAnimation(currentTranX, nextTranX, DURATION);
            da.Completed += (o1, e1) =>
            {
                CurrentIndex += forward ? 1 : -1;
                if (AnimationComplte != null)
                {
                    AnimationComplte(this, e1);
                }
            };

            NavigationPanelTranslateTransform.BeginAnimation(TranslateTransform.XProperty, da);
        }

        #region CurrentIndex

        /// <summary>  
        /// The <see cref="CurrentIndex" /> dependency property's name.  
        /// </summary>  
        public const string CurrentIndexPropertyName = "CurrentIndex";

        /// <summary>  
        /// Gets or sets the value of the <see cref="CurrentIndex" />  
        /// property. This is a dependency property.  
        /// </summary>  
        public int CurrentIndex
        {
            get
            {
                return (int)GetValue(CurrentIndexProperty);
            }
            set
            {
                SetValue(CurrentIndexProperty, value);
            }
        }

        /// <summary>  
        /// Identifies the <see cref="CurrentIndex" /> dependency property.  
        /// </summary>  
        public static readonly DependencyProperty CurrentIndexProperty = DependencyProperty.Register(
            CurrentIndexPropertyName,
            typeof(int),
            typeof(NavigationPanel),
            new UIPropertyMetadata(-1, OnCurrentIndexChanged));

        private static void OnCurrentIndexChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
        {
            (d as NavigationPanel).OnCurrentIndexChanged((int)e.OldValue, (int)e.NewValue);
        }

        protected virtual void OnCurrentIndexChanged(int oldIndex, int newIndex)
        {
            NextIsValid = ValidateNext();
            PreviousIsValid = ValidatePrevious();
        }

        #endregion // CurrentIndex


        #region NextIsValid

        /// <summary>  
        /// The <see cref="NextIsValid" /> dependency property's name.  
        /// </summary>  
        public const string NextIsValidPropertyName = "NextIsValid";

        /// <summary>  
        /// Gets or sets the value of the <see cref="NextIsValid" />  
        /// property. This is a dependency property.  
        /// </summary>  
        public bool NextIsValid
        {
            get
            {
                return (bool)GetValue(NextIsValidProperty);
            }
            set
            {
                SetValue(NextIsValidProperty, value);
            }
        }

        /// <summary>  
        /// Identifies the <see cref="NextIsValid" /> dependency property.  
        /// </summary>  
        public static readonly DependencyProperty NextIsValidProperty = DependencyProperty.Register(
            NextIsValidPropertyName,
            typeof(bool),
            typeof(NavigationPanel),
            new UIPropertyMetadata(false));

        #endregion // NextIsValid

        #region PreviousIsValid

        /// <summary>  
        /// The <see cref="PreviousIsValid" /> dependency property's name.  
        /// </summary>  
        public const string PreviousIsValidPropertyName = "PreviousIsValid";

        /// <summary>  
        /// Gets or sets the value of the <see cref="PreviousIsValid" />  
        /// property. This is a dependency property.  
        /// </summary>  
        public bool PreviousIsValid
        {
            get
            {
                return (bool)GetValue(PreviousIsValidProperty);
            }
            set
            {
                SetValue(PreviousIsValidProperty, value);
            }
        }

        /// <summary>  
        /// Identifies the <see cref="PreviousIsValid" /> dependency property.  
        /// </summary>  
        public static readonly DependencyProperty PreviousIsValidProperty = DependencyProperty.Register(
            PreviousIsValidPropertyName,
            typeof(bool),
            typeof(NavigationPanel),
            new UIPropertyMetadata(false));

        #endregion // PreviousIsValid




    }

因爲是第一次作複雜一點的界面,因此代碼不少地方都比較爛,可是最終效果仍是挺好的,畢竟不是圖片拼的,我就知足了~~~請高手指點,因爲是工做代碼,不方便給出所有,本來能把DEMO放出,惋惜被我刪了...裏面還有我本身費盡作的很多樣式...哎,不再能隨便刪了,多多備份....指針

相關文章
相關標籤/搜索