Tuesday, April 22, 2008

Visual Studio 2005 - IDE Enhancements

IDE Enhancements
IDE Enhancements
IDE Simplification
Class Designer
Exporting/Importing Options Settings
Smart Tags for Controls
Snaplines
Data Tips
Edit and Continue
Exception Assistant
Code Editing
Line Revision Marks
IntelliSense Improvements
IntelliSense Code Snippets
Source Browsing
Windows Forms
Windows Forms Overview
Video Overview
UI Development
ToolStrips, LayoutPanels, SplitContainer, Menus, StatusStrips
WebBrowser
XP Theme Support
Data Centric Applications
Configure Data Source Wizard and Data Sources Window
Data-Controls
BindingSource
BindingNavigator
DataGridView
MaskedTextBox
Attaching a Database with Your Application Displaying Data from a Web Service -->
Displaying Data from a Business Object
Connect the Dots
Performing Tasks Asynchronously
Deployment
ClickOnce
VSTO
VSTO Overview
Video Overview
Building UI
Smart Docs
Actions Pane
Smart Tags
Data-Centric Applications
XML Support, Separation of view from Data, Data Binding, Data Caching
Displaying Data from a Web Service
Displaying Data from a Database
Displaying Data from XML Source
Enhanced Data Binding
.NET CF
Overview
Video Overview
.NET Framework Enhancements
Authentication
Web Services
Multi-Threading Capability
COM Interop
Support for IPv6
Security
Building UI
DocumentList and ComboBox
MonthCalendar, DateTimePicker, PictureBox, ProgressBar
Help Interaction with Notifications
HardwareButton and ScreenOrientation
Data Binding
Data-Centric Applications
IDE Integration
Web Service Support
SQL 2005 Mobile Edition
Synchronization and Replication
Web Services
Testing
Deployment
Smart Client
Smart Client Overview
Rich User Experience
Web Services Offline & Online Support
Easy Deployment and Change Management
Device Adaptability
Responsiveness
Local Resource Utilization
Building Applications
Building and Debugging
New Build System
Large Builds
Multi-Processor Builds
Home Professional Set default to show samples in VB C# C++ J#

Windows Forms - XP Theme Support
Visual Studio 2005 improves support for Windows XP Themes in Windows Forms 2.0. Windows XP Theme support allows your Windows Form applications to have a completely modern and up-to-date look and feel. In the past, many of you had difficulty implementing the Windows XP look and feel for you client applications. It was particularly confusing when dealing with EnableVisualStyles() and trying to figure out why certain controls still wouldn't render properly. Moreover, you had to set each control's FlatStyle property to System.

All of these issues have been fixed in Windows Forms 2.0. Applications created with Visual Studio 2005 call EnableVisualStyles() by default. Additionally, the controls render properly without your having explicitly to set the FlatStyle property.
This walkthrough demonstrates Windows Forms 2.0's improved support for visual styles by building a simple application with controls for switching between four different visual styles.
See the Visual Studio 2005 Client Development Guided Tour Walkthrough Requirements page for a list of the requirements needed to run this walkthrough. NOTE: In addition to these requirements, this walkthrough requires the Windows XP operating system, configured to use the Windows XP style in the Display control panel Appearance tab.

1Open Visual Studio 2005 and create a new Windows Application project named "XP Themes". Using the Solution Explorer, open the Program.cs file. Note that visual styles have been enabled by default.
(NOTE: In Visual Basic you will need to click the Show All Files button in the Solution Explorer window before opening the designer partial file and then expand My Project Application.myapp and then open Application.Designer.vb. In J#, the designer-generated code is within a named region Windows Form Designer generated code in the Form1.jsl source code file.)
VB C# J#










2Switch over to the Form1 design view. Drag the following controls from the Toolbox onto Form1:
Button
CheckBox
ComboBox
TabControl
3Note that the controls appear with XP styling by default.
VB C# J#
VB C# J#













The new Application object property, VisualStyleState, can be used to enable visual styles selectively on client areas, non-client areas, or across the entire control. (The client area is the area inside the form, exclusive of the title bar and scroll bars.) By default, an application's VisualStyleState is ClientAndNonClientAreasEnabled. This means that the entire form, in terms of title bars and the client area, will be set to use XP Themes.
4Drag four RadioButton controls from the Toolbox onto Form1. Accept the default names. Resize the form to fit. In the Properties window, set each control's Text property to the following values, respectively:

radioButton1: ClientAndNonClientAreasEnabled
radioButton2: ClientAreaEnabled
radioButton3: NonClientAreaEnabled
radioButton4: NoneEnabled
VB C# J#
VB C# J#
VB C# J#


















Each of the RadioButton controls has a corresponding VisualStyleState enumeration value. Clicking one of the four RadioButton controls will assign the Application.VisualStyleState property to the corresponding value and refresh the Form. This demonstrates how to selectively enable visual styles.

5In the Properties window for radioButton1, click on the lightning bolt icon switch to the event. In the Click event, type radioButton_Click and press Enter. In the resulting handler add the following:
VB C# J#
If RadioButton1.Checked Then Application.VisualStyleState = _ VisualStyleState.ClientAndNonClientAreasEnabledElseIf RadioButton2.Checked Then Application.VisualStyleState = _ VisualStyleState.ClientAreaEnabledElseIf RadioButton3.Checked Then Application.VisualStyleState = _ VisualStyleState.NonClientAreaEnabledElseIf RadioButton4.Checked Then Application.VisualStyleState = _ VisualStyleState.NoneEnabledEnd If
' Repaint the form and all child controls.Me.Invalidate(True)
6To the top of Form1 add a reference to System.Windows.Forms.VisualStyles:
imports System.Windows.Forms.VisualStyles
VB
C#
J#
using System.Windows.Forms.VisualStyles;
VB
C#
J#
import System.Windows.Forms.VisualStyles.*;
7Right-click Form1 and select View Designer. In the Properties window for each of the three remaining RadioButton controls, set the Click event to radioButton_Click.
8Select the Debug Start Debugging menu command (F5) to run the application.
9In the running application, click each of the four RadioButton controls to see the effect of selectively enabling visual styles.












VB C# J#
if (radioButton1.Checked) { Application.VisualStyleState = VisualStyleState.ClientAndNonClientAreasEnabled; }else if (radioButton2.Checked) { Application.VisualStyleState = VisualStyleState.ClientAreaEnabled; }else if (radioButton3.Checked) { Application.VisualStyleState = VisualStyleState.NonClientAreaEnabled; }else if (radioButton4.Checked) { Application.VisualStyleState = VisualStyleState.NoneEnabled; }// Repaint the form and all child controls.this.Invalidate(true);
VB C# J#
if (radioButton1.get_Checked()){ Application.set_VisualStyleState( VisualStyleState.ClientAndNonClientAreasEnabled);}else if (radioButton2.get_Checked()){ Application.set_VisualStyleState( VisualStyleState.ClientAreaEnabled);}else if (radioButton3.get_Checked()){ Application.set_VisualStyleState( VisualStyleState.NonClientAreaEnabled);}else if (radioButton4.get_Checked()){ Application.set_VisualStyleState( VisualStyleState.NoneEnabled);}// Repaint the form and all child controls.this.Invalidate(true);
6To the top of Form1 add a reference to System.Windows.Forms.VisualStyles:
VB C# J#
imports System.Windows.Forms.VisualStyles
VB C# J#
using System.Windows.Forms.VisualStyles;
VB C# J#
import System.Windows.Forms.VisualStyles.*;
7Right-click Form1 and select View Designer. In the Properties window for each of the three remaining RadioButton controls, set the Click event to radioButton_Click.
8Select the Debug Start Debugging menu command (F5) to run the application.
9In the running application, click each of the four RadioButton controls to see the effect of selectively enabling visual styles.







































The first screenshot shows how the application looks when ClientAndNonClientAreasEnabled is selected. The entire application renders in the XP style. When only the client area is enabled all the controls on the Form reflect the XP style. The non-client areas, however, such as the Form border and its controls, do not. The remaining two options are reflected in the other screenshots.
In closing its worth pointing out that Visual Studio 2005 extends support for visual styles into owner-drawn controls as well. To draw your own control you can subclass the VisualStyleRenderer class, which includes methods for drawing different parts of the current theme. Use VisualStyleInformation class to determine details about the current style. You can use derived renderers, such as ButtonRenderer, to draw pieces of these controls in your own control, allowing you to leverage the rendering capabilities of existing controls. This allows you to draw your control through visual styles-aware parts of common controls, reducing the amount of custom rendering code required. You can tell what element parts are predefined by using VisualStyleRenderer.IsElementDefined method call. By using suitable renderers when available, and calling out to custom rendering code otherwise, you can future-proof your code, as future version of Windows Forms may add more elements and parts.
© 2006 Microsoft Corporation. All rights reserved. Terms of Use.
SetTabs();
FindHtmLinkNode();

No comments: