■ ImageLayer 클래스의 RequestDataLoading 이벤트를 사용해 웹 데이터 서비스에서 이미지 타일 로드시 진행 상태를 표시하는 방법을 보여준다.
▶ 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 |
using System; using DevExpress.XtraEditors; using DevExpress.XtraMap; namespace TestProject { /// <summary> /// 메인 폼 /// </summary> public partial class MainForm : XtraForm { //////////////////////////////////////////////////////////////////////////////////////////////////// Field ////////////////////////////////////////////////////////////////////////////////////////// Private #region Field /// <summary> /// 요청 수 /// </summary> private int requestCount = 0; #endregion //////////////////////////////////////////////////////////////////////////////////////////////////// Constructor ////////////////////////////////////////////////////////////////////////////////////////// Public #region 생성자 - MainForm() /// <summary> /// 생성자 /// </summary> public MainForm() { InitializeComponent(); this.openStreetMapDataProvider.WebRequest += openStreetMapDataProvider_WebRequest; this.imageLayer.RequestDataLoading += imageLayer_RequestDataLoading; this.imageLayer.DataLoaded += imageLayer_DataLoaded; } #endregion //////////////////////////////////////////////////////////////////////////////////////////////////// Method ////////////////////////////////////////////////////////////////////////////////////////// Private //////////////////////////////////////////////////////////////////////////////// Event #region OPEN STREET MAP 데이터 공급자 웹 요청시 처리하기 - openStreetMapDataProvider_WebRequest(sender, e) /// <summary> /// OPEN STREET MAP 데이터 공급자 웹 요청시 처리하기 /// </summary> /// <param name="sender">이벤트 발생자</param> /// <param name="e">이벤트 인자</param> private void openStreetMapDataProvider_WebRequest(object sender, MapWebRequestEventArgs e) { e.UserAgent = "XtraMap Getting Started - Connect to OpenStreetMap"; } #endregion #region 이미지 레이어 데이터 로드 요청시 처리하기 - imageLayer_RequestDataLoading(sender, e) /// <summary> /// 이미지 레이어 데이터 로드 요청시 처리하기 /// </summary> /// <param name="sender">이벤트 발생자</param> /// <param name="e">이벤트 인자</param> private void imageLayer_RequestDataLoading(object sender, EventArgs e) { this.requestCount++; UpdateProgressBar(); } #endregion #region 이미지 레이어 데이터 로드시 처리하기 - imageLayer_DataLoaded(sender, e) /// <summary> /// 이미지 레이어 데이터 로드시 처리하기 /// </summary> /// <param name="sender">이벤트 발생자</param> /// <param name="e">이벤트 인자</param> private void imageLayer_DataLoaded(object sender, DataLoadedEventArgs e) { this.progressBar.Value = 100; this.progressBar.Visible = false; this.progressLabel.Visible = false; this.requestCount = 0; } #endregion //////////////////////////////////////////////////////////////////////////////// Function #region 진행바 업데이트하기 - UpdateProgressBar() /// <summary> /// 진행바 업데이트하기 /// </summary> private void UpdateProgressBar() { if(!this.progressBar.Visible) { this.progressBar.Visible = true; } if(!this.progressLabel.Visible) { this.progressLabel.Visible = true; } this.progressBar.Value = (int)(100 * (this.requestCount - 1) / this.requestCount); } #endregion } } |