Как назвать MSBuild от C#

Все ответы пока включают полную замену поведения кнопки по умолчанию чем-то другим. Тем не менее, IMHO полезно и важно понять, что можно изменить только ту часть, которую вы заботитесь о , отредактировав существующий шаблон по умолчанию для элемента XAML.

В случай обращения с эффектом наведения на кнопку WPF, изменение внешнего вида в элементе WPF Button вызвано Trigger в стиле по умолчанию для Button, который основан на свойстве IsMouseOver и устанавливает свойства Background и BorderBrush элемента верхнего уровня Border в шаблоне управления. Фон элемента Button находится под фоном элемента Border, поэтому изменение свойства Button.Background не мешает видеть эффект зависания.

С некоторыми усилиями вы можете отменить это поведение с помощью ваш собственный сеттер, но поскольку элемент, который вам нужно затронуть, находится в шаблоне, а не напрямую доступен в вашем собственном XAML, этот подход будет сложным, а IMHO слишком сложным.

Еще один вариант - использовать как Content для Button, а не Background. Если вам нужен дополнительный контент по графике, вы можете объединить их с Grid в качестве объекта верхнего уровня в контенте.

Однако, если вы буквально просто хотите полностью отключить эффект наведения (скорее чем просто сокрытие), вы можете использовать Visual Studio XAML Designer:

  1. Во время редактирования вашего XAML выберите вкладку «Дизайн» .
  2. На вкладке «Дизайн» найдите кнопку, для которой вы хотите отключить эффект.
  3. Щелкните правой кнопкой мыши эту кнопку и выберите «Редактировать шаблон / Изменить Копия ... ". Выберите в подсказке, где вы хотите разместить новый ресурс шаблона. Это будет ничего не делать, но на самом деле Дизайнер добавит новые ресурсы, где вы сказали, и изменил элемент кнопки, чтобы ссылаться на стиль, который использует эти ресурсы в качестве шаблона кнопки.
  4. Теперь вы может пойти редактировать этот стиль. Самое простое - удалить или закомментировать (например, Ctrl + E, C) элемент <Trigger Property="IsMouseOver" Value="true">...</Trigger>. Конечно, вы можете внести любые изменения в желаемый шаблон.

Когда вы закончите, стиль кнопки будет выглядеть примерно так:

<p:Style x:Key="FocusVisual">
  <Setter Property="Control.Template">
    <Setter.Value>
      <ControlTemplate>
        <Rectangle Margin="2" SnapsToDevicePixels="true" Stroke="{DynamicResource {x:Static SystemColors.ControlTextBrushKey}}" StrokeThickness="1" StrokeDashArray="1 2"/>
      </ControlTemplate>
    </Setter.Value>
  </Setter>
</p:Style>
<SolidColorBrush x:Key="Button.Static.Background" Color="#FFDDDDDD"/>
<SolidColorBrush x:Key="Button.Static.Border" Color="#FF707070"/>
<SolidColorBrush x:Key="Button.MouseOver.Background" Color="#FFBEE6FD"/>
<SolidColorBrush x:Key="Button.MouseOver.Border" Color="#FF3C7FB1"/>
<SolidColorBrush x:Key="Button.Pressed.Background" Color="#FFC4E5F6"/>
<SolidColorBrush x:Key="Button.Pressed.Border" Color="#FF2C628B"/>
<SolidColorBrush x:Key="Button.Disabled.Background" Color="#FFF4F4F4"/>
<SolidColorBrush x:Key="Button.Disabled.Border" Color="#FFADB2B5"/>
<SolidColorBrush x:Key="Button.Disabled.Foreground" Color="#FF838383"/>
<p:Style x:Key="ButtonStyle1" TargetType="{x:Type Button}">
  <Setter Property="FocusVisualStyle" Value="{StaticResource FocusVisual}"/>
  <Setter Property="Background" Value="{StaticResource Button.Static.Background}"/>
  <Setter Property="BorderBrush" Value="{StaticResource Button.Static.Border}"/>
  <Setter Property="Foreground" Value="{DynamicResource {x:Static SystemColors.ControlTextBrushKey}}"/>
  <Setter Property="BorderThickness" Value="1"/>
  <Setter Property="HorizontalContentAlignment" Value="Center"/>
  <Setter Property="VerticalContentAlignment" Value="Center"/>
  <Setter Property="Padding" Value="1"/>
  <Setter Property="Template">
    <Setter.Value>
      <ControlTemplate TargetType="{x:Type Button}">
        <Border x:Name="border" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" SnapsToDevicePixels="true">
          <ContentPresenter x:Name="contentPresenter" Focusable="False" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" Margin="{TemplateBinding Padding}" RecognizesAccessKey="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}"/>
        </Border>
        <ControlTemplate.Triggers>
          <Trigger Property="IsDefaulted" Value="true">
            <Setter Property="BorderBrush" TargetName="border" Value="{DynamicResource {x:Static SystemColors.HighlightBrushKey}}"/>
          </Trigger>
          <!--<Trigger Property="IsMouseOver" Value="true">
            <Setter Property="Background" TargetName="border" Value="{StaticResource Button.MouseOver.Background}"/>
            <Setter Property="BorderBrush" TargetName="border" Value="{StaticResource Button.MouseOver.Border}"/>
          </Trigger>-->
          <Trigger Property="IsPressed" Value="true">
            <Setter Property="Background" TargetName="border" Value="{StaticResource Button.Pressed.Background}"/>
            <Setter Property="BorderBrush" TargetName="border" Value="{StaticResource Button.Pressed.Border}"/>
          </Trigger>
          <Trigger Property="IsEnabled" Value="false">
            <Setter Property="Background" TargetName="border" Value="{StaticResource Button.Disabled.Background}"/>
            <Setter Property="BorderBrush" TargetName="border" Value="{StaticResource Button.Disabled.Border}"/>
            <Setter Property="TextElement.Foreground" TargetName="contentPresenter" Value="{StaticResource Button.Disabled.Foreground}"/>
          </Trigger>
        </ControlTemplate.Triggers>
      </ControlTemplate>
    </Setter.Value>
  </Setter>
</p:Style>

(Примечание: вы можете опустить квалификацию пространства имен p: XML в фактическом коде & hellip; я предоставляю их здесь только потому, что форматировщик XML-кода Stack Overflow путается элементами <Style/>, которые не имеют полностью квалифицированного имени с пространством имен XML.)

Если вы хотите применить тот же стиль к другим кнопкам, вы можете просто щелкнуть их правой кнопкой мыши и выбрать «Редактировать шаблон / применить ресурс» и выбрать стиль, который вы только что добавили для первой кнопки. Вы даже можете сделать стиль стилем по умолчанию для всех кнопок, используя обычные методы применения стиля по умолчанию к элементам в XAML.

25
задан David Schmitt 11 February 2009 в 12:21
поделиться

2 ответа

Да, добавьте ссылку на Microsoft.Build.Engine и используйте Механизм класс.

пз: Заботьтесь для ссылки на правильную версию. Существует 2,0 и 3,5 блока, и Вы будете иметь к , удостоверяются, что все получают правильный .

28
ответ дан David Schmitt 15 October 2019 в 16:13
поделиться

For a .NET 2.0-specific version, you can use the following:

Engine engine = new Engine();
engine.BinPath = System.Environment.GetFolderPath(System.Environment.SpecialFolder.System)
    + @"\..\Microsoft.NET\Framework\v2.0.50727";

FileLogger logger = new FileLogger();
logger.Parameters = @"logfile=C:\temp\test.msbuild.log";
engine.RegisterLogger(logger);

string[] tasks = new string[] { "MyTask" };
BuildPropertyGroup props = new BuildPropertyGroup();
props.SetProperty("parm1","hello Build!");

try
{
  // Call task MyTask with the parm1 property set
  bool success = engine.BuildProjectFile(@"C:\temp\test.msbuild",tasks,props);
}
catch (Exception ex)
{
  // your error handler
}
finally
{
 engine.UnregisterAllLoggers();
 engine.UnloadAllProjects();
}
16
ответ дан 28 November 2019 в 21:01
поделиться
Другие вопросы по тегам:

Похожие вопросы: