• 利用WPF绘图


    C#入门经典 25章的一个例子,利用WPF绘图。

    XAML:

    <Window xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
            xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
            x:Class="Ch25Ex01.MainWindow"
            Title="Color Spinner" Height="370" Width="270">
        <Window.Resources>
            <Storyboard x:Key="Spin">
                <DoubleAnimationUsingKeyFrames BeginTime="00:00:00"
                    Storyboard.TargetName="ellipse1"
                    Storyboard.TargetProperty=
       "(UIElement.RenderTransform).(TransformGroup.Children)[0].(RotateTransform.Angle)"    
                    RepeatBehavior="Forever">
                    <SplineDoubleKeyFrame KeyTime="00:00:10" Value="360"/>
                </DoubleAnimationUsingKeyFrames>
                <DoubleAnimationUsingKeyFrames BeginTime="00:00:00"
                    Storyboard.TargetName="ellipse2"
                    Storyboard.TargetProperty=
        "(UIElement.RenderTransform).(TransformGroup.Children)[0].(RotateTransform.Angle)"   
                    RepeatBehavior="Forever">
                    <SplineDoubleKeyFrame KeyTime="00:00:10" Value="-360" />
                </DoubleAnimationUsingKeyFrames>
                <DoubleAnimationUsingKeyFrames BeginTime="00:00:00"
                    Storyboard.TargetName="ellipse3"
                    Storyboard.TargetProperty=
        "(UIElement.RenderTransform).(TransformGroup.Children)[0].(RotateTransform.Angle)"   
                    RepeatBehavior="Forever">
                    <SplineDoubleKeyFrame KeyTime="00:00:05" Value="360" />
                </DoubleAnimationUsingKeyFrames>
                <DoubleAnimationUsingKeyFrames BeginTime="00:00:00"
                    Storyboard.TargetName="ellipse4"
                    Storyboard.TargetProperty=
        "(UIElement.RenderTransform).(TransformGroup.Children)[0].(RotateTransform.Angle)"
                    RepeatBehavior="Forever">
                    <SplineDoubleKeyFrame KeyTime="00:00:05" Value="-360" />
                </DoubleAnimationUsingKeyFrames>
            </Storyboard>
        </Window.Resources>
        <Window.Triggers>
            <EventTrigger RoutedEvent="FrameworkElement.Loaded">
                <BeginStoryboard Storyboard="{StaticResource Spin}"
                    x:Name="Spin_BeginStoryBoard" />
            </EventTrigger>
            <EventTrigger RoutedEvent="ButtonBase.Click" SourceName="goButton" >
                <ResumeStoryboard BeginStoryboardName="Spin_BeginStoryBoard" />
            </EventTrigger>
            <EventTrigger RoutedEvent="ButtonBase.Click" SourceName="stopButton" >
                <PauseStoryboard BeginStoryboardName="Spin_BeginStoryBoard"/>
            </EventTrigger>
        </Window.Triggers>
        
        <Window.Background>
            <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                <GradientStop Color="#FFFFFFFF" Offset="0" />
                <GradientStop Color="#FFFFC45A" Offset="1" />
            </LinearGradientBrush>
        </Window.Background>
        
        <Grid>
            <Ellipse Margin="50,50,0,0" Name="ellipse5" Stroke="Black" Height="150"
                HorizontalAlignment="Left" VerticalAlignment="Top" Width="150">
                <Ellipse.Effect>
                    <BlurEffect Radius="10" />
                </Ellipse.Effect>
                <Ellipse.Fill>
                    <RadialGradientBrush>
                        <GradientStop Color="#FF000000" Offset="1" />
                        <GradientStop Color="#FFFFFFFF" Offset="0.306" />
                    </RadialGradientBrush>
                </Ellipse.Fill>
            </Ellipse>
            <Ellipse Margin="15,85,0,0" Name="ellipse1" Stroke="{x:Null}"
                Height="80" HorizontalAlignment="Left" VerticalAlignment="Top" 
                Width="120" Fill="Red" Opacity="0.5" RenderTransformOrigin="0.92,0.5">
                <Ellipse.Effect>
                    <BlurEffect />
                </Ellipse.Effect>
                <Ellipse.RenderTransform>
                    <TransformGroup>
                        <RotateTransform Angle="0"/>
                    </TransformGroup>
                </Ellipse.RenderTransform>
            </Ellipse>
            <Ellipse Margin="85,15,0,0" Name="ellipse2" Stroke="{x:Null}"
                Height="120" HorizontalAlignment="Left" VerticalAlignment="Top" 
                Width="80" Fill="Blue" Opacity="0.5" RenderTransformOrigin="0.5,0.92">
                <Ellipse.Effect>
                    <BlurEffect />
                </Ellipse.Effect>
                <Ellipse.RenderTransform>
                    <TransformGroup>
                        <RotateTransform Angle="0"/>
                    </TransformGroup>
                </Ellipse.RenderTransform>
            </Ellipse>
            <Ellipse Margin="115,85,0,0" Name="ellipse3" Stroke="{x:Null}"
                Height="80" HorizontalAlignment="Left" VerticalAlignment="Top" 
                Width="120" Opacity="0.5" Fill="Yellow"
                RenderTransformOrigin="0.08,0.5">
                <Ellipse.Effect>
                    <BlurEffect />
                </Ellipse.Effect>
                <Ellipse.RenderTransform>
                    <TransformGroup>
                        <RotateTransform Angle="0"/>
                    </TransformGroup>
                </Ellipse.RenderTransform>
            </Ellipse>
            <Ellipse Margin="85,115,0,0" Name="ellipse4" Stroke="{x:Null}"
                Height="120" HorizontalAlignment="Left" VerticalAlignment="Top" 
                Width="80" Opacity="0.5" Fill="Green"
                RenderTransformOrigin="0.5,0.08">
                <Ellipse.Effect>
                    <BlurEffect />
                </Ellipse.Effect>
                <Ellipse.RenderTransform>
                    <TransformGroup>
                        <RotateTransform Angle="0"/>
                    </TransformGroup>
                </Ellipse.RenderTransform>
            </Ellipse>
            <Button Height="23" HorizontalAlignment="Left" Margin="20,0,0,56"
                Name="goButton" VerticalAlignment="Bottom" Width="75" Content="Go" />
            <Button Height="23" HorizontalAlignment="Left" Margin="152,0,0,56"
                Name="stopButton" VerticalAlignment="Bottom" Width="75" Content="Stop" />
            <Button Height="23" HorizontalAlignment="Left" Margin="85,0,86,16"
                Name="toggleButton" VerticalAlignment="Bottom" Width="75" Content="Toggle" Click="toggleButton_Click" />
        </Grid>
    </Window>

    交互逻辑:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Data;
    using System.Windows.Documents;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Imaging;
    using System.Windows.Navigation;
    using System.Windows.Shapes;
    using System.Windows.Media.Animation;
    
    namespace Ch25Ex01
    {
        /// <summary>
        /// MainWindow.xaml 的交互逻辑
        /// </summary>
        public partial class MainWindow : Window
        {
            public MainWindow()
            {
                InitializeComponent();
            }
    
            private void toggleButton_Click(object sender, RoutedEventArgs e)
            {
                Storyboard spinStoryboard = Resources["Spin"] as Storyboard;
                if (spinStoryboard != null)
                {
                    if (spinStoryboard.GetIsPaused(this))
                        spinStoryboard.Resume(this);
                    else
                        spinStoryboard.Pause(this);
                }
            }
        }
    }

    最终效果很炫哦,推荐自己动手实现。

  • 相关阅读:
    docker – 在容器引擎上定义/ dev / shm的大小
    Redis集群创建
    Go 语言陷阱
    使用python进行视频图片提取
    使用ffmpeg进行视频图片提取
    app端性能测试
    为什么需要分布式ID?你项目中是怎么做的?
    JavaGuide学习记录——java容器
    【追根究底】doCreateBean中为什么会对earlySingletonExposure处理两次
    老板急坏了,公司网站的 HTTPS 过期了,获取免费SSL证书
  • 原文地址:https://www.cnblogs.com/ZRBYYXDM/p/5286164.html
Copyright © 2020-2023  润新知