Archive

Archive for 2009

Windows Live Writer: Plug-ins to Format Content through CSS Classes

September 30th, 2009

I like using CSS classes to format specific content of my blog posts, in order to keep my formatting centralized. I prefer HTML that looks like this over inline styles:

If you invoke the <span class="code">GetData</span> method, ...

 

Quickly inserting CSS directives is something you can’t easily do with Windows Live Writer. This started to annoy me while writing an article, so I came up with two simple plug-ins that do just that: Formatting selected text through CSS classes.

 

Read more…

Making WPF Popups Work in Windowless Applications

September 23rd, 2009

I’ve first encountered this issue with my WPF NotifyIcon, and now again while writing a plug-in for Windows Live Writer: If you try to display a WPF popup without any Windows open (the Popup is the only UI component there is), certain controls such as TextBox, ListView, or ListBox don’t receive proper mouse and/or keyboard input, and cannot be selected.

The reason for this issue is buried in the WPF framework, and how it interacts with Windows. Fellow WPF Disciple Andrew Smith pointed me in the right direction:

 

…because a Popup’s HWND has the WS_EX_NOACTIVATE so the WPF framework will not attempt to actually focus the associated hwnd (because its usually used with a window and you don’t want to deactivate the window when you focus something in the popup).

 

Accordingly, you’ll have to fiddle with Windows Interop to make things work. Here’s the snippet:

 

public static class WinApi
{
  /// <summary>
  /// Gives focus to a given window.
  /// </summary>
  [DllImport("USER32.DLL")]
  public static extern bool SetForegroundWindow(IntPtr hWnd);


  public static void ActivatePopup(Popup popup)
  {
    //try to get a handle on the popup itself (via its child)
    HwndSource source = (HwndSource)PresentationSource.FromVisual(popup.Child);
    IntPtr handle = source.Handle;

    //activate the popup
    SetForegroundWindow(handle);
  }
}
Author: Categories: WPF, WPF Controls Tags:

WPF NotifyIcon – Bugfix and WinForms Support

September 22nd, 2009

I released an update to my WPF NotifyIcon, which fixes two issues:

  • Interactive Popups should now fully support all control types.
  • The control can now be used in Windows Forms projects, if you need more functionality than the built-in component.

The solution now comes with an additional WinForms sample project, which shows how to display a WPF user control as an interactive popup.

image

     

    Download link and further information can be found on the control’s home page:
    http://www.hardcodet.net/wpf-notifyicon

    Author: Categories: Uncategorized Tags:

    NetDrives 1.0.1 Fixes Settings Bug

    September 22nd, 2009

    I updated NetDrives, which fixes a registry issue when it comes to saving the application settings. Functionality is still the same, though.

    Project Page: http://www.hardcodet.net/netdrives

    Author: Categories: NetDrives Tags:

    Snippet Time: Helper Libraries for C# / WPF

    September 14th, 2009

    I just made a few minor updates to two libraries which assemble as set of helper classes for C# and WPF and thought: Why not share them? The libraries aren’t really intended to be used directly in your code, but you might find one or another helper method or snippet that might make a nice addition to your own toolbox 🙂

     

    Hardcodet.Commons (C#, .NET 3.5)

    Common helper classes and snippets (simple base classes, file management, weak events, extension methods etc.)

     

    Hardcodet.Wpf.Commons (C#, .NET 3.5)

    Stuff I commonly use in WPF projects, such as checking for design time, base classes for commands and converters, data binding helpers and other stuff.

     

    I’ll keep these libraries up-to-date, version history will be posted here.

     

    History:

    2009.09.14  Initial blog release

    Author: Categories: C#, Open Source, WPF Tags: , ,

    Linked Images in WPF Projects – Bad Idea?

    August 10th, 2009

    I discovered today that images that are included in a VS project as links are compiled differently than images that are stored as part of the project. This one might cost you quite some time, so here’s a few observations on the issue…

    Look at this simple project that contains two image files. One file is part of the project (physically stored in the Images folder), the other one added as a link. Both files have the same build action (Resource):

    image

     

    Now, if you declare these two images the same way, everything appears to be fine in the designer (both Visual Studio and Blend):

    <Window x:Class="WpfApplication2.Window1"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="Window1" Height="150" Width="150">
        <StackPanel VerticalAlignment="Center">
          <Image Source="/Images/Add-Item.png" Stretch="None" />
          <Image Source="/Images/Remove-Item.png" Stretch="None"/>
        </StackPanel>
    </Window>

     

    image

     

    However, as soon as you compile and start your application, the linked image does not appear – obviously, the runtime could not resolve it at runtime:

     

    image

     

    I was quite surprised about this until I reverted to Reflector, which reveals that the linked image was embedded differently than the other one. Here’s the resource entries of the compiled WPF application:

    image

     

    As you can see, the linked image (Remove-Item.png) was included without the folder name, in lower case. Accordingly, I had to adjust the image source in XAML as follows:

    <Window x:Class="WpfApplication2.Window1"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="Window1" Height="150" Width="150">
        <StackPanel VerticalAlignment="Center">
          <Image Source="/Images/Add-Item.png" Stretch="None" />
          <Image Source="/remove-item.png" Stretch="None"/>
        </StackPanel>
    </Window>

     

    This one works at runtime. BUT it breaks the designer. I’m not too happy about that one – whether a file is linked to or not should not affect the outcome of the compiled build all. I’m not too sure whether this was a conscious decision or a bug, but it sure is a major pain.

    Update: Microsoft confirmed this to be a bug, which should be fixed in the upcoming version of the framework / VS2010. So for now, linking is out of the picture for me.

    Author: Categories: WPF Controls Tags: