Blue Theme Orange Theme Green Theme Red Theme
 
DevExpress Free UI Controls
Home | Forums | Videos | Advertise | Certifications | Downloads | Blogs | Interviews | Jobs | Beginners | Training
 | Consulting  
Submit an Article Submit a Blog 
 Jump to
Skip Navigation Links
TechnologyExpand Technology
WebsiteExpand Website
Mindcracker MVP Summit 2012
Search :       Advanced Search »
Home » Windows Controls C# » FlowLayoutPanel in C#

FlowLayoutPanel in C#

The FlowLayoutPanel control is a container control that provides dynamically layout for the child controls that can be arranged horizontally or vertically. The flow direction of the control sets the direction of arrangements of controls.

Author Rank :
Page Views : 15935
Downloads : 213
Rating :
 Rate it
Level : Beginner
   Print Read/Post comments Post a comment  Similar Articles  
   Email to a friend  Bookmark  Author's other articles  
Download Files:
FlowLayoytPanelSampleInCSharp.zip
 
 
Team Foundation Server Hosting
Become a Sponsor
 Tag Cloud
 Latest Jobs
More ... 
 Latest Interview Questions
More ... 


The FlowLayoutPanel control is a container control that provides dynamically layout for the child controls that can be arranged horizontally or vertically. The flow direction of the control sets the direction of arrangements of controls.

Creating a FlowLayoutPanel

We can create a FlowLayoutPanel control using the Forms designer at design-time or using the FlowLayoutPanel class in code at run-time (also known as dynamically).

Design-time

To create a FlowLayoutPanel control at design-time, you simply drag and drop a FlowLayoutPanel control from Toolbox to a Form in Visual Studio. After you drag and drop a FlowLayoutPanel on a Form, the FlowLayoutPanel looks like Figure 1. Once a FlowLayoutPanel is on the Form, you can move it around and resize it using mouse and set its properties and events.

FlowLayoutImg1.jpg 

Figure 1

Run-time

Creating a FlowLayoutPanel control at run-time is merely a work of creating an instance of FlowLayoutPanel class, set its properties and adds FlowLayoutPanel class to the Form controls.

First step to create a dynamic FlowLayoutPanel is to create an instance of FlowLayoutPanel class. The following code snippet creates a FlowLayoutPanel control object.

FlowLayoutPanel dynamicFlowLayoutPanel = new FlowLayoutPanel();

 

In the next step, you may set properties of a FlowLayoutPanel control. The following code snippet sets location, size and Name properties of a FlowLayoutPanel.

dynamicFlowLayoutPanel.Location = new System.Drawing.Point(26, 12);

dynamicFlowLayoutPanel.Name = "FlowLayoutPanel1";

dynamicFlowLayoutPanel.Size = new System.Drawing.Size(228, 20);

dynamicFlowLayoutPanel.TabIndex = 0;

 

Once the FlowLayoutPanel control is ready with its properties, the next step is to add the FlowLayoutPanel to a Form. To do so, we use Form.Controls.Add method that adds FlowLayoutPanel control to the Form controls and displays on the Form based on the location and size of the control. The following code snippet adds a FlowLayoutPanel control to the current Form.

 

this.Controls.Add(dynamicFlowLayoutPanel);

Setting FlowLayoutPanel Properties

After you place a FlowLayoutPanel control on a Form, the next step is to set its properties.

The easiest way to set properties is from the Properties Window. You can open Properties window by pressing F4 or right click on a control and select Properties menu item. The Properties window looks like Figure 2.

FlowLayoutImg2.jpg
Figure 2

Name

Name property represents a unique name of a FlowLayoutPanel control. It is used to access the control in the code. The following code snippet sets and gets the name and text of a FlowLayoutPanel control.

dynamicFlowLayoutPanel.Name = "FlowLayoutPanel1";

Location, Height, Width and Size

The Location property takes a Point that specifies the starting position of the FlowLayoutPanel on a Form. You may also use Left and Top properties to specify the location of a control from the left top corner of the Form.  The Size property specifies the size of the control. We can also use Width and Height property instead of Size property. The following code snippet sets Location, Width, and Height properties of a FlowLayoutPanel control.

dynamicFlowLayoutPanel.Location = new System.Drawing.Point(26, 12);

dynamicFlowLayoutPanel.Size = new System.Drawing.Size(228, 20);

Flow Direction

The FlowDirection property represents the direction in which child controls are arranged on a panel. The FlowDirection property is represented by a FlowDirection enumeration that has four self-explanatory values LeftToRight, TopDown, RightToLeft, and BottomUp values.  The following code snippet sets and gets the Value properties at run-time.

dynamicFlowLayoutPanel.FlowDirection = FlowDirection.RightToLeft;

 

OK say we have a Form with a few controls on it arranged on a FlowLayoutPanel as displayed in Figure 3. The default flow direction of a FlowLayoutPanel is LeftToRight. Make sure WrapContents property is set to False.

 

FlowLayoutImg3.jpg
Figure 3

If we change FlowDirection to RightToLeft, new Form looks like Figure 4.

 

FlowLayoutImg4.jpg
Figure 4

If we change FlowDirection to TopDown, new Form looks like Figure 5.

 

 

FlowLayoutImg5.jpg
Figure 5

If we change FlowDirection to BottomUp, new Form looks like Figure 6.

 

FlowLayoutImg6.jpg
Figure 6

Wrap Contents

The WrapContents property represents if the contents of a FlowLayoutPanel control are wrapped or not. The following code snippet sets the WrapContents property to true.

dynamicFlowLayoutPanel.WrapContents = true;

 

Figure 7 is a FlowLayoutPanel with WrapContents set to false.

 

FlowLayoutImg7.jpg
Figure 7

Figure 8 is the same FlowLayoutPanel with WrapContents set to true.

 

FlowLayoutImg8.jpg
Figure 8

Summary
In this article, we discussed discuss how to create a FlowLayoutPanel control in Windows Forms at design-time as well as run-time. After that, we saw how to use various properties and methods.

Comment Request!
Thank you for reading this post. Please post your feedback, question, or comments about this post Here.
Login to add your contents and source code to this article
 [Top] Rate this article
 
 About the author
 
Mahesh Chand
Mahesh is the founder of C# Corner and Mindcracker Network, an author of several .NET programming books and a Microsoft MVP for 6 consecutive years. In his day to day work, Mahesh is a Senior Software Consultant with over 14 years of IT industry experience building systems for Financial and Banking, Engineering & Architectural, Imaging, Construction, Biological & Pharmaceuticals, Healthcare and Education industries. His expertise is Windows Forms, ASP.NET, Silverlight, WPF, WCF, Visual Studio 2010, SQL Server, and Oracle.  If you are looking for a Sharepoint, Windows Forms, ASP.NET, WPF, Silverlight, C#, VB.NET, Oracle, and SQL Server Consultant in Philadelphia area or remote location, drop me a line at MAHESH [AT] C-SHARPCORNER [DOT] COM.
Looking for C# Consulting?
C# Consulting is founded in 2002 by the founders of C# Corner. Unlike a traditional consulting company, our consultants are well-known experts in .NET and many of them are MVPs, authors, and trainers. We specialize in Microsoft .NET development and utilize Agile Development and Extreme Programming practices to provide fast pace quick turnaround results. Our software development model is a mix of Agile Development, traditional SDLC, and Waterfall models.
Click here to learn more about C# Consulting.
 
Introducing MaxV - one click. infinite control. Hyper-V Hosting from MaximumASP.
Finally – a virtual platform that delivers next-generation Windows Server 2008 Hyper-V virtualization technology from a managed hosting partner you can truly depend on. Visit www.maximumasp.com/max for a FREE 30 day trial. Hurry offer ends soon. Climb aboard the MaxV platform and take advantage of High Availability, Intelligent Monitoring, Recurrent Backups, and Scalability – with no hassle or hidden fees. As a managed hosting partner focused solely on Microsoft technologies since 2000, MaximumASP is uniquely qualified to provide the superior support that our business is built on. Unparalleled expertise with Microsoft technologies lead to working directly with Microsoft as first to offer IIS 7 and SQL 2008 betas in a hosted environment; partnering in the Go Live Program for Hyper-V; and product co-launches built on WS 2008 with Hyper-V technology.
Dynamic PDF
ceTE software specializes in components for dynamic PDF generation and manipulation. The DynamicPDF™ product line allows you to dynamically generate PDF documents, merge PDF documents and new content to existing PDF documents from within your applications.
Discover the top 5 tips for understanding .NET
Ricky Leeks presents the top 5 tips for understanding .NET Interoperability. Learn more.
Nevron Chart for .NET 2010.1 Now Available
The leading .NET charting control now features PDF, Flash and Silverlight export, visualization of large datasets and more. Deliver true charting functionality to your BI, Scorecard, Presentation or Scientific apps. Download evaluation now.
ASP.NET 4 Hosting
Get 2 Months Free of ASP.NET Hosting for Only $4.95/month! Receive FREE MS SQL and MySQL Databases Including ASP.NET 4/3.5, MVC 3.0, Silverlight 4, Windows 2008/IIS 7.0 Plus FREE IIS 7 Modules. Host UNLIMITED ASP.NET Web Sites – Click Here!
 
 Post a Feedback, Comment, or Question about this article
Subject:
Comment:
Mindcracker MVP Summit 2012
Become a Sponsor
 Comments

 © 2012  contents copyright of their authors. Rest everything copyright Mindcracker. All rights reserved.