Tech
News
Videos
Forums
Jobs
Books
Events
More
Interviews
Live
Learn
Training
Career
Members
Blogs
Challenges
Certification
Contribute
Article
Blog
Video
Ebook
Interview Question
Collapse
Feed
Dashboard
Wallet
Learn
Achievements
Network
Refer
Rewards
SharpGPT
Premium
Contribute
Article
Blog
Video
Ebook
Interview Question
Register
Login
Working with WPF Frame using C# and XAML
WhatsApp
Mahesh Chand
6y
387.3k
0
6
100
Article
The WPF Frame control using XAML and C# supports content navigation within content. A Frame can be hosted within a Window, NavigationWindow, Page, UserControl, or a FlowDocument control.
How to create a Frame in WPF
This XAML code shows how to create a Frame control and sets its Source property to load a XAML page within it.
<
Window
x:Class
=
"FrameSample.Window1"
xmlns
=
"http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x
=
"http://schemas.microsoft.com/winfx/2006/xaml"
Title
=
"Window1"
Height
=
"300"
Width
=
"300"
>
<
Grid
>
<
TextBlock
>
Outside area of frame
</
TextBlock
>
<
Frame
Source
=
"Page1.xaml"
>
</
Frame
>
</
Grid
>
</
Window
>
The Window looks like this. The Purple area is the Page1.xaml and the White area is outside of the frame.
Now you can manage the contents of a frame the way you want.
For example, the following code rotates the contents of the frame to a 45 degree angle.
<
Frame
Source
=
"Page1.xaml"
>
<
Frame.LayoutTransform
>
<
RotateTransform
Angle
=
"45"
/>
</
Frame.LayoutTransform
>
</
Frame
>
The new output looks like this.
How to Navigate to a URI in a WPF Frame
The following code creates a Frame within a window and adds a button control to the window. On the button click event handler we will navigate to a URI using a Frame.
<
Window
x:Class
=
"FrameSample.Window1"
xmlns
=
"http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x
=
"http://schemas.microsoft.com/winfx/2006/xaml"
Title
=
"Window1"
Height
=
"300"
Width
=
"300"
>
<
Grid
>
<
TextBlock
>
Outside area of frame
</
TextBlock
>
<
Frame
Name
=
"FrameWithinGrid"
>
</
Frame
>
<
Button
Height
=
"23"
Margin
=
"114,12,25,0"
Name
=
"button1"
VerticalAlignment
=
"Top"
Click
=
"button1_Click"
>
Navigate to C# Corner
</
Button
>
</
Grid
>
</
Window
>
The Navigate method of Frame is used to navigate to a URI. The following code navigates to Page1.xaml.
private
void
button1_Click(
object
sender, RoutedEventArgs e)
{
FrameWithinGrid.Navigate(
new
System.Uri(
"Page1.xaml"
,
UriKind.RelativeOrAbsolute));
}
The following code navigates to an external website URL and opens the ASPX page within a Frame.
FrameWithinGrid.Source =
new
Uri(
"http://www.c-sharpcorner.com/Default.aspx"
, UriKind.Absolute);
If you need to open a URI in a new browser window, the following code will do that. This code first creates a NavigationWindow and then sets its Source to a URI.
NavigationWindow window =
new
NavigationWindow();
Uri source =
new
Uri(
"http://www.c-sharpcorner.com/Default.aspx"
, UriKind.Absolute);
window.Source = source; window.Show();
WPF Frame
Frame in XAML
Up Next
Ebook Download
View all
Programming XAML
Read by 12.4k people
Download Now!
Learn
View all
Mindcracker
Founded in 2003, Mindcracker is the authority in custom software development and innovation. We put best practices into action. We deliver solutions based on consumer and industry analysis.
Membership not found