앞에 만들었던 WANIGrid 솔루션에 Grid Control에 걸맞는 레이아웃을 잡도록한다.
Grid Control에 VScrollBar와 HScrollBar를 추가하고 Control 사이즈 변경에 따라 VScrollBar와 HScrollBar가 제 위치를 찾아 갈 수 있도록 레이아웃을 만들도록 한다.
Control 사이즈를 넘는 많은 Row와 Column의 데이터를 제공하기 위해서 가로/세로 스크롤 바를 추가해서 전체 데이터를 볼 수 있도록 해야 한다.
WANIGrid Control의 사이즈는 기본적으로 Width: 200, Height: 150 으로 설정한다.
HScrollBar와 VScrollBar를 추가한다.
HScrollBar의 Name은 hScrollBar, VScrollBar의 Name은 vScrollBar로 한다.
Control 초기화 되거나 사이즈가 변경될 때 ScrollBar를 초기화 할 수 있는 함수를 만들도록 한다.
ScrollBar초기화 시에는 가로 스크롤바의 위치와 세로 스크롤바의 위치를 Control 사이즈 내에서 맨 아래와 맨 우측에 위치할 있도록 설정을 해야 한다.
또한 세로 스크롤바의 경우 Grid Header 영역 아래에서 부터 시작을 해야 하기에 Grid Header 영역을 20으로 잡아서 Control 영역 상단의 20만큼의 공간을 비워두고 스크롤이 위치되도록 한다.
이때 Grid의 Header 영역을 보관하는 변수를 WANIGrid.cs에 추가하도록 한다.
private int topHeaderHeight = 20; //Grid의 Header 높이
Control 내의 가로/세로 스크롤바의 위치를 초기화하는 메소드를 만든다.
///
/// HScrollBar, VScrollBar 초기화
///
public void InitializeScollBar()
{
//가로 스크롤바 설정
hScrollBar.Left = 1;
hScrollBar.Width = Width - vScrollBar.Width - 2;
hScrollBar.Top = Height - hScrollBar.Height - 2;
//세로 스크롤바 설정
vScrollBar.Left = Width - vScrollBar.Width - 2;
vScrollBar.Top = topHeaderHeight + 2;
vScrollBar.Height = Height - topHeaderHeight - hScrollBar.Height - 4;
}
이렇게 만들어진 메소드 InitializeScollBar()를 Form Load 이벤트, Resize 이벤트, 사이즈 변경 이벤트, Client 사이즈 변경 이벤트가 발생할 때 호출하도록 한다.
private void WANIGrid_Load(object sender, EventArgs e)
{
InitializeScollBar();
}
private void WANIGrid_Resize(object sender, EventArgs e)
{
InitializeScollBar();
}
private void WANIGrid_SizeChanged(object sender, EventArgs e)
{
InitializeScollBar();
}
private void WANIGrid_ClientSizeChanged(object sender, EventArgs e)
{
InitializeScollBar();
}
이렇게 함으로써 Form의 사이즈가 변경될 때마다 가로/세로 스크롤바의 위치가 항상 Control의 Bottom과 Right에 위치하게 된다.
이렇게 Control의 기본 Layout에 대한 간단한 설정을 마무리 했다.
다음 회차에서는 이렇게 만들어진 Grid Control 레이아웃에서 그려져야 할 Grid Header 영역에 대해서 이야기 하고자 한다. Grid Header 영역은 분량이 많은 관계로 여러 번에 걸쳐서 설명을 할 예정이다.
지금까지 설명한 소스코드와 WANIGrid Control를 삽입해서 테스트 할 수 있는 WinForm 프로젝트가 아래의 zip파일에 포함되어져 있다.
압축을 풀고 WANI Grid 폴더 아래의 솔루션 파일을 읽어 들이면 WANIGridTest 프로젝트도 같이 포함된다.
'WinForm > Grid Control 만들기' 카테고리의 다른 글
5. HeaderBuilder Class 살펴보기 (0) | 2019.06.03 |
---|---|
4. Grid Header 관련 클래스 (0) | 2019.05.29 |
3. Grid Header에 대한 생각 (0) | 2019.05.25 |
1. 구현하고자 하는 Grid Control에 대한 생각 (0) | 2019.05.21 |
0. Grid Control 만들기를 시작하며... (0) | 2019.05.19 |