C# Visual Studio不显示设计数据

C# Visual Studio不显示设计数据,c#,visual-studio,xaml,mvvm,uwp,C#,Visual Studio,Xaml,Mvvm,Uwp,我目前正在尝试将设计数据集成到我的UWP应用程序中。 对于这种方法,我遵循了microsoft的步骤: 我的问题是:数据不会显示。只有绑定的名称: 但我期望的结果更像这样:(旧版本,运行时屏幕) 那么我是如何实现它的呢我决定使用“DesignInstance”,因为已经有了一个ViewModel,以后无论如何都会使用它(它目前在运行时工作正常) 因此,我的“MockupViewModel”继承自原始ViewModel,并在默认构造函数中创建虚拟值: public class MockupMo

我目前正在尝试将设计数据集成到我的UWP应用程序中。 对于这种方法,我遵循了microsoft的步骤:

我的问题是:数据不会显示。只有绑定的名称:

但我期望的结果更像这样:(旧版本,运行时屏幕)

那么我是如何实现它的呢
我决定使用“DesignInstance”,因为已经有了一个ViewModel,以后无论如何都会使用它(它目前在运行时工作正常)

因此,我的“MockupViewModel”继承自原始ViewModel,并在默认构造函数中创建虚拟值:

public class MockupModel
    : WeatherViewModel
{
    public MockupModel() : base()
    {
        Random Randomizer = new Random();

        CurrentData.PrecipitationIcon = WeatherUnicodeIconLib.Neutral.Snow;
        CurrentData.PrecipitationValue = 0.234;
        CurrentData.SunRiseSetIcon = WeatherUnicodeIconLib.Miscellaneous.SunRise;
        CurrentData.SunRiseSetTime = DateTime.Now;
        CurrentData.TemperatureUnitIcon = WeatherUnicodeIconLib.Miscellaneous.Celsius;
        CurrentData.TemperatureValue = -20.75;
        CurrentData.WeatherStatusDescription = "lorem ipsum";
        CurrentData.WeatherStatusIcon = OpenWeatherMapUnicodeStatusIconAdapter.GetStandardIconUnicode(200);
        CurrentData.WindDirectionDegrees = 240.7;
        CurrentData.WindSpeedIcon = WeatherUnicodeIconLib.GetBeaufortScaleIcon(3);

        for (int i = 0; i < 7; i++)
        {
            DailyForecastViewModel NewForecastItem = new DailyForecastViewModel();

            NewForecastItem.Day = DateTime.Now;
            NewForecastItem.TemperatureValue = Randomizer.Next(-30, 30);
            NewForecastItem.WeatherSatusIcon = OpenWeatherMapUnicodeStatusIconAdapter.GetStandardIconUnicode(300);
            NewForecastItem.WindSpeedIcon = WeatherUnicodeIconLib.GetBeaufortScaleIcon(Randomizer.Next(0, 12));

            DailyForecast.Add(NewForecastItem);
        }
    }
}
公共类模型
:WeatherViewModel
{
公共MockupModel():base()
{
随机随机发生器=新随机();
CurrentData.DepartmentIcon=weatherUnicode deiconlib.Neutral.Snow;
CurrentData.DepositionValue=0.234;
CurrentData.SunRiseSetIcon=WeatherUnicodeConlib.Miscellaneous.SunRise;
CurrentData.SunRiseSetTime=DateTime.Now;
CurrentData.TemperatureUnitIcon=WeatherUnicodeConlib.Miscellaneous.Celsius;
CurrentData.TemperatureValue=-20.75;
CurrentData.WeatherStatusDescription=“lorem ipsum”;
CurrentData.WeatherStatusIcon=OpenWeatherMapUnicodestStatusIconadapter.GetStandardIconUnicode(200);
CurrentData.WindDirectionDegrees=240.7;
CurrentData.WindPeedicon=WeatherUnicode deiconlib.GetBeaufortScaleIcon(3);
对于(int i=0;i<7;i++)
{
DailyForecastViewModel NewForecastItem=新的DailyForecastViewModel();
NewForecastItem.Day=DateTime.Now;
NewForecastItem.TemperatureValue=随机数发生器.Next(-30,30);
NewForecastItem.WeatherSatusIcon=OpenWeatherMapUnicodestStationAdapter.GetStandardIconUnicode(300);
NewForecastItem.WindSpeedIcon=WeatherUnicodeIconLib.GetBeaufortScaleIcon(Randomizer.Next(0,12));
DailyForecast.Add(新预测项);
}
}
}
之后,MockupViewModel被添加到XAML代码中:
(查看UserControl标题/标记的最后一行)


白色
90

您还可以在github上查看我的项目,以了解更详细的代码:


我希望你能在这里帮助我,并提前感谢

解决方案是确保您使用的是x86配置,然后单击Visual Studio中名为“启用项目代码”的按钮:

这两个地点的更多信息:

(一)

禁用项目代码可能会导致设计时数据丢失。另一种方法是调试设计器中运行的代码

(二)

在按钮被禁用的情况下,您仍然可以以某种方式编辑UI,因为将显示属性的名称,并且您至少可以设置字体、字体大小、前景颜色等,这总比没有好


不幸的是,VisualStudio2015的设计器有很多缺陷,因此您可能会遇到与我相同的问题:当您切换到x86时,VisualStudio会抱怨“无效标记”。Blend for Visual Studio具有相同的按钮,如果没有帮助,您可以尝试该按钮或VS2017 RC。

我随机点击了答案

  • 将平台设置为“x86”后(x64不工作)
  • 并启用“项目代码” (关于Mikael Koskinen的回答)
  • 将我的“MockupModel”移动到与UserControl相同的命名空间 (关于)
  • 我将配置设置为“释放”

    -->成功了

因此,我检查了我的项目设置以找出原因,并比较了配置
(发布/调试)

  • 检查后,“优化代码”(用于调试配置)
  • 和重建(重要)

  • -->不再有“无效标记”
  • -->模型和他的数据显示正确


这在“VS 2015 Community Update3”和“VS 2017 RC”中对我很有效。

没有任何帮助:(我尝试启用“设计数据”,将配置设置为x86,并在2017 RC中执行此操作。但“无效标记”仍然存在:(在VS2017中也是如此。这个解决方案立即解决了我的问题!我花了几个小时想知道为什么我的模拟数据突然没有生成。一定是在过去几周的某个时候点击了“项目代码”按钮而没有意识到(顺便提一下,上面的所有内容仍然适用于VS2019 16.3.10…)这个问题仍然存在于VS2017。
<UserControl
x:Class="WeatherControl.WeatherControl"
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"
mc:Ignorable="d"
xmlns:vm="using:WeatherControl.ViewModel"
d:DataContext="{d:DesignInstance Type=vm:MockupModel, IsDesignTimeCreatable=True}">

<UserControl.Resources>
    <SolidColorBrush x:Key="FontColor">White</SolidColorBrush>
    <x:Double x:Key="MainInfoFontSize">90</x:Double>

    <Style TargetType="TextBlock">
        <Setter Property="FontFamily" Value="{StaticResource WeatherIcons}"/>
        <Setter Property="Foreground" Value="{StaticResource FontColor}"/>
        <Setter Property="FlowDirection" Value="LeftToRight"/>
        <Setter Property="FontSize" Value="30"/>
    </Style>
</UserControl.Resources>

<StackPanel Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
    <StackPanel
        HorizontalAlignment="Stretch"
        Padding="20">

        <StackPanel
            HorizontalAlignment="Stretch"
            Orientation="Horizontal"
            FlowDirection="RightToLeft">
            <TextBlock
                x:Name="SunSetRiseTime"
                Text="{Binding Path=CurrentData.SunRiseSetTime}"/>
            <TextBlock
                x:Name="SunSetRiseIcon"
                Text="{Binding Path=CurrentData.SunRiseSetIcon}"
                Margin="10,0,30,0"/>

            <TextBlock
                x:Name="WindDirectionIcon"
                Text="&#xf0b1;"
                RenderTransformOrigin="0.5 0.5">
                <TextBlock.RenderTransform>
                    <RotateTransform Angle="{Binding Path=CurrentData.WindDirectionDegrees}"/>
                </TextBlock.RenderTransform>
            </TextBlock>
            <TextBlock
                x:Name="WindBeaufortScaleIcon"
                Text="{Binding Path=CurrentData.WindSpeedIcon}"
                Margin="10,0,30,0"/>

            <TextBlock
                x:Name="PrecipitationIcon"
                Text="{Binding Path=CurrentData.PrecipitationIcon}"
                RenderTransformOrigin="0.5 0.5"/>
            <TextBlock
                x:Name="PrecipitationIconValue"
                Text="{Binding Path=CurrentData.PrecipitationValue}"
                Margin="10,0,20,0"/>
        </StackPanel>

        <StackPanel
            x:Name="MainInfos"
            HorizontalAlignment="Stretch"
            Orientation="Horizontal"
            FlowDirection="RightToLeft">
            <TextBlock
                x:Name="TemperatureUnitIcon"
                Text="{Binding Path=CurrentData.TemperatureUnitIcon}"
                FontSize="{StaticResource MainInfoFontSize}"
                Margin="0,0,10,0"/>
            <TextBlock
                Name="TemperatureValue"
                Text="{Binding Path=CurrentData.TemperatureValue}"
                FlowDirection="LeftToRight"
                FontSize="{StaticResource MainInfoFontSize}"
                Margin="0,0,40,0"/>
            <TextBlock
                x:Name="WeatherStatusIcon"
                Text="{Binding Path=CurrentData.WeatherStatusIcon}"
                FontSize="{StaticResource MainInfoFontSize}"/>
        </StackPanel>

        <TextBlock
                x:Name="WeatherDescription"
                Text="{Binding Path=CurrentData.WeatherStatusDescription}"
                TextAlignment="Right"
                Margin="0,0,0,20"/>

        <ListBox
            x:Name="DailyForecasts"
            HorizontalAlignment="Stretch"
            FlowDirection="RightToLeft"
            Background="Transparent"
            ItemsSource="{Binding Path=DailyForecast}">
            <ListBox.ItemContainerStyle>
                <Style TargetType="ListBoxItem">
                    <Setter Property="Padding" Value="0"/>

                </Style>
            </ListBox.ItemContainerStyle>
            <ListBox.ItemTemplate>
                <DataTemplate>
                    <StackPanel
                        x:Name="ForecastDay"
                        Orientation="Horizontal"
                        HorizontalAlignment="Stretch">
                        <TextBlock
                            x:Name="WindSpeed"
                            TextAlignment="Left"
                            Text="{Binding Path=WindSpeedIcon}"
                            Width="70"/>
                        <TextBlock
                            x:Name="Temperature"
                            TextAlignment="Right"
                            Text="{Binding Path=TemperatureValue}"
                            Width="60"/>
                        <TextBlock
                            x:Name="WeatherIcon"
                            TextAlignment="Center"
                            Text="{Binding Path=WeatherSatusIcon}"
                            Width="100"/>
                        <TextBlock
                            x:Name="DayName"
                            TextAlignment="Left"
                            Text="{Binding Path=Day}"
                            Width="70"/>
                    </StackPanel>
                </DataTemplate>
            </ListBox.ItemTemplate>
        </ListBox>
    </StackPanel>
</StackPanel>