您的设置使其非常模糊,但如果您知道要查找什么,您可以看到时间:
以下代码工作正常:
using System;
namespace WpfApp1
{
using System.Windows;
using System.Windows.Media;
using System.Windows.Threading;
public sealed class MainTimer : FrameworkElement
{
private DispatcherTimer Timer = new DispatcherTimer();
public MainTimer()
{
// what you are looking for is InvalidateVisual
this.Timer.Tick += (sender, args) => this.InvalidateVisual();
// changed your timespan to a more appropriate value
this.Timer.Interval = TimeSpan.FromSeconds(1);
this.Timer.Start();
}
protected override void OnRender(DrawingContext drawingContext)
{
string mode = "12";
System.Diagnostics.Trace.WriteLine("Rendering");
if (Application.Current.MainWindow != null)
{
if (mode == "24")
{
drawingContext.DrawText(new FormattedText(DateTime.Now.ToLongTimeString(), System.Globalization.CultureInfo.CurrentCulture, FlowDirection.LeftToRight, new Typeface("Microsoft PhagsPa"), 50, new SolidColorBrush(Color.FromArgb(50, 235, 255, 255))), new Point(0, -15));
}
else
{
string st = "";
if (DateTime.Now.Hour > 12)
{
st = ((DateTime.Now.Hour - 12).ToString("00") + " : " + DateTime.Now.Minute.ToString("00") + " : " + DateTime.Now.Second.ToString("00")) + " pm";
}
else
{
st = ((DateTime.Now.Hour).ToString("00") + " : " + DateTime.Now.Minute.ToString("00") + " : " + DateTime.Now.Second.ToString("00")) + " am";
}
drawingContext.DrawText(new FormattedText(st, System.Globalization.CultureInfo.CurrentCulture, FlowDirection.LeftToRight, new Typeface("Microsoft PhagsPa"), 40, new SolidColorBrush(Color.FromArgb(50, 200, 255, 255))), new Point(0, -12));
}
}
}
}
}
使用XAML:
<Window x:Class="WpfApp1.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:WpfApp1"
mc:Ignorable="d"
Title="MainWindow" Height="350" Width="525">
<Grid>
<local:MainTimer/>
</Grid>
</Window>
它每秒都在渲染。
我仍然认为
这
这不是自定义渲染的目的,您可以在XAML中通过计时器更改viewmodel来执行此操作
价值
. 然而,如果情况变得更复杂,您可能会对
this other thread
以及详细说明如何使用绘图组提高性能的答案。