Poznámka:
Přístup k této stránce vyžaduje autorizaci. Můžete se zkusit přihlásit nebo změnit adresáře.
Přístup k této stránce vyžaduje autorizaci. Můžete zkusit změnit adresáře.
Toto téma ukazuje, jak rozšířit skleněné rámečky systému Windows Vista do klientské oblasti aplikace Windows Presentation Foundation (WPF).
Poznámka:
Tento příklad bude fungovat jenom na počítači se systémem Windows Vista, na kterém běží Správce desktopových oken (DWM) s povoleným sklem. Windows Vista Home Basic edition nepodporuje průhledný efekt skla. Oblasti, které by se obvykle vykreslovaly s průhledným skleněným efektem v jiných edicích systému Windows Vista, jsou vykresleny neprůhledné.
Rozšířený skleněný okraj v adresním řádku
Následující obrázek znázorňuje rám skla rozšířený do adresního řádku aplikace Internet Explorer 7:
K rozšíření skleněného rámečku v aplikaci WPF je potřeba přístup k nespravovanému rozhraní API. Následující příklad kódu provádí platformní volání (pinvoke) pro dvě rozhraní API potřebná k roztažení rámce do klientské oblasti. Každé z těchto rozhraní API je deklarováno ve třídě s názvem NonClientRegionAPI.
[StructLayout(LayoutKind.Sequential)]
public struct MARGINS
{
public int cxLeftWidth; // width of left border that retains its size
public int cxRightWidth; // width of right border that retains its size
public int cyTopHeight; // height of top border that retains its size
public int cyBottomHeight; // height of bottom border that retains its size
};
[DllImport("DwmApi.dll")]
public static extern int DwmExtendFrameIntoClientArea(
IntPtr hwnd,
ref MARGINS pMarInset);
<StructLayout(LayoutKind.Sequential)>
Public Structure MARGINS
Public cxLeftWidth As Integer ' width of left border that retains its size
Public cxRightWidth As Integer ' width of right border that retains its size
Public cyTopHeight As Integer ' height of top border that retains its size
Public cyBottomHeight As Integer ' height of bottom border that retains its size
End Structure
<DllImport("DwmApi.dll")>
Public Shared Function DwmExtendFrameIntoClientArea(ByVal hwnd As IntPtr, ByRef pMarInset As MARGINS) As Integer
End Function
DwmExtendFrameIntoClientArea je funkce DWM, která rozšiřuje rámec do klientské oblasti. Přebírá dva parametry, úchyt okna a strukturu MARGINS. MARGINS se používá k tomu, aby DWM sdělil, o kolik má být rámec rozšířen do klientské oblasti.
Rozšířený skleněný rám při události Načtení
Chcete-li použít funkci DwmExtendFrameIntoClientArea, musí být získán popisovač okna. Ve WPF lze úchyt okna získat z vlastnosti Handle objektu HwndSource. V následujícím příkladu se rámec rozšiřuje do klientské oblasti při události Loaded okna.
void OnLoaded(object sender, RoutedEventArgs e)
{
try
{
// Obtain the window handle for WPF application
IntPtr mainWindowPtr = new WindowInteropHelper(this).Handle;
HwndSource mainWindowSrc = HwndSource.FromHwnd(mainWindowPtr);
mainWindowSrc.CompositionTarget.BackgroundColor = Color.FromArgb(0, 0, 0, 0);
// Get System Dpi
System.Drawing.Graphics desktop = System.Drawing.Graphics.FromHwnd(mainWindowPtr);
float DesktopDpiX = desktop.DpiX;
float DesktopDpiY = desktop.DpiY;
// Set Margins
NonClientRegionAPI.MARGINS margins = new NonClientRegionAPI.MARGINS();
// Extend glass frame into client area
// Note that the default desktop Dpi is 96dpi. The margins are
// adjusted for the system Dpi.
margins.cxLeftWidth = Convert.ToInt32(5 * (DesktopDpiX / 96));
margins.cxRightWidth = Convert.ToInt32(5 * (DesktopDpiX / 96));
margins.cyTopHeight = Convert.ToInt32(((int)topBar.ActualHeight + 5) * (DesktopDpiX / 96));
margins.cyBottomHeight = Convert.ToInt32(5 * (DesktopDpiX / 96));
int hr = NonClientRegionAPI.DwmExtendFrameIntoClientArea(mainWindowSrc.Handle, ref margins);
//
if (hr < 0)
{
//DwmExtendFrameIntoClientArea Failed
}
}
// If not Vista, paint background white.
catch (DllNotFoundException)
{
Application.Current.MainWindow.Background = Brushes.White;
}
}
Rozšířený skleněný rámeček v klientské zóně
Následující příklad ukazuje jednoduché okno, ve kterém je rámec rozšířen do klientské oblasti. Rámec je rozšířen za horním okrajem, který obsahuje dva TextBox objekty.
<Window x:Class="SDKSample.Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Extended Glass in WPF" Height="300" Width="400"
Loaded="OnLoaded" Background="Transparent"
>
<Grid ShowGridLines="True">
<DockPanel Name="mainDock">
<!-- The border is used to compute the rendered height with margins.
topBar contents will be displayed on the extended glass frame.-->
<Border Name="topBar" DockPanel.Dock="Top" >
<Grid Name="grid">
<Grid.ColumnDefinitions>
<ColumnDefinition MinWidth="100" Width="*"/>
<ColumnDefinition Width="Auto"/>
</Grid.ColumnDefinitions>
<TextBox Grid.Column="0" MinWidth="100" Margin="0,0,10,5">Path</TextBox>
<TextBox Grid.Column="1" MinWidth="75" Margin="0,0,0,5">Search</TextBox>
</Grid>
</Border>
<Grid DockPanel.Dock="Top" >
<Grid.ColumnDefinitions>
<ColumnDefinition/>
</Grid.ColumnDefinitions>
<TextBox Grid.Column="0" AcceptsReturn="True"/>
</Grid>
</DockPanel>
</Grid>
</Window>
Následující obrázek znázorňuje rám skla rozšířený do aplikace WPF:
Viz také
- Přehled Správce desktopových oken
- Přehled rozostření ve Správci oken plochy
- DwmExtendFrameIntoClientArea
.NET Desktop feedback