■ ThemeEditor 클래스를 사용해 차트 테마를 설정하는 방법을 보여준다.
▶ MainForm.cs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 |
using System; using System.Drawing; using System.Windows.Forms; using Steema.TeeChart.Drawing; using Steema.TeeChart.Editors; using Steema.TeeChart.Styles; using Steema.TeeChart.Themes; namespace TestProject { /// <summary> /// 메인 폼 /// </summary> public partial class MainForm : Form { //////////////////////////////////////////////////////////////////////////////////////////////////// Field ////////////////////////////////////////////////////////////////////////////////////////// Private #region Field /// <summary> /// 테마 에디터 /// </summary> private ThemeEditor themeEditor; #endregion //////////////////////////////////////////////////////////////////////////////////////////////////// Constructor ////////////////////////////////////////////////////////////////////////////////////////// Public #region 생성자 - MainForm() /// <summary> /// 생성자 /// </summary> public MainForm() { InitializeComponent(); Text = "ThemeEditor 클래스 : 차트 테마 설정하기"; this.tChart.Panel.Pen = new ChartPen(Color.Black); Bar bar = new Bar(this.tChart.Chart); bar.ColorEach = true; bar.FillSampleValues(); this.themeEditor = new ThemeEditor(this.tChart.Chart, null); object[] objectCollection; this.themeEditor.AddChartThemes(out objectCollection); this.themeListBox.DisplayMember = "Name"; this.themeListBox.Items.Clear(); foreach(object item in objectCollection) { this.themeListBox.Items.Add ( new ThemeItem { Name = item.GetType().ToString().Replace("Steema.TeeChart.Themes.", string.Empty), Theme = item as Theme } ); } this.themeListBox.SelectedIndexChanged += themeListBox_SelectedIndexChanged; this.themeEditorButton.Click += themeEditorButton_Click; this.applyByCodeButton.Click += applyByCodeButton_Click; this.themeListBox.SelectedIndex = 0; } #endregion //////////////////////////////////////////////////////////////////////////////////////////////////// Method ////////////////////////////////////////////////////////////////////////////////////////// Private //////////////////////////////////////////////////////////////////////////////// Event #region 테마 리스트 박스 선택 인덱스 변경시 처리하기 - themeListBox_SelectedIndexChanged(sender, e) /// <summary> /// 테마 리스트 박스 선택 인덱스 변경시 처리하기 /// </summary> /// <param name="sender">이벤트 발생자</param> /// <param name="e">이벤트 인자</param> private void themeListBox_SelectedIndexChanged(object sender, EventArgs e) { if(this.themeListBox.SelectedIndex != -1) { ThemeItem item = this.themeListBox.SelectedItem as ThemeItem; item.Theme.Apply(); } } #endregion #region 테마 에디터 버튼 클릭시 처리하기 - themeEditorButton_Click(sender, e) /// <summary> /// 테마 에디터 버튼 클릭시 처리하기 /// </summary> /// <param name="sender">이벤트 발생자</param> /// <param name="e">이벤트 인자</param> private void themeEditorButton_Click(object sender, EventArgs e) { this.themeEditor.ShowDialog(); this.themeListBox.SelectedIndex = 0; } #endregion #region 코드로 적용 버튼 클릭시 처리하기 - applyByCodeButton_Click(sender, e) /// <summary> /// 코드로 적용 버튼 클릭시 처리하기 /// </summary> /// <param name="sender">이벤트 발생자</param> /// <param name="e">이벤트 인자</param> private void applyByCodeButton_Click(object sender, EventArgs e) { XPTheme xpTheme = new XPTheme(this.tChart.Chart); xpTheme.Apply(); } #endregion } } |