この投稿はパスワードで保護されているため抜粋文はありません。
Tag Archives: WPF
保護中: LineGraph コントロールの実装方法 Step2
この投稿はパスワードで保護されているため抜粋文はありません。
保護中: LineGraph コントロールの実装方法 Step1
この投稿はパスワードで保護されているため抜粋文はありません。
ItemsControl で折れ線グラフのプロットは無理があり過ぎる
以前の記事で ItemsControl を利用してデータ点をプロットする方法をちょろっと紹介しましたが、 よくよく調べてみると、やっぱりデータ点が多いときは描画に時間がかかってしまいます。 そうは言ってもよくわかんないの … Continue reading
LineGraph という名のカスタムコントロールを作ってみる その 2
今回はグラフの目盛線の描画方法を紹介しますが, その前に基本となるクラスを説明しないことには, 途中で意味不明なコードが出てきますので, まずはその基本クラスを簡単に紹介します. 紹介する基本クラスは NotifyPro … Continue reading
カスタムコントロールの作り方
せっかくなのでカスタムコントロールを作る方法を少しだけ. 画面は VS2010Pro のものですが, 上位の Visual Studio もほとんど同じでしょう. Express の場合は多分メニューにカスタムコントロー … Continue reading
LineGraph という名のカスタムコントロールを作ってみる その 1
WPF でグラフ表示をするためのコントロールを自作したい. WPF Toolkit とか使えばいいじゃんとかいうツッコミもあるかもしれないが, 結局自分の思うようなカスタマイズをするにはやっぱり自作しかない. とりあえず … Continue reading
ResourceDictionary を分割して使う
ResourceDictionary でリソースを書けるのはいいけど, MainView では使わないけど Sub1View と Sub2View では使うものがあったりすると困る. それにひとつの ResourceDi … Continue reading
ItemsControl でデータ点を並べる
WPF でグラフ表示をしたいと常々思ってはいるんだけど, VC++ のように自分で描画させるコードをしこしこ書くのはなんか違うと思い, web 上で探しまくった結果, 結局のところ ItemsControl を使うんじゃ … Continue reading
INotifyPropertyChanged を実装した抽象クラス
試しに INotifyPropertyChanged インターフェースと IDisposable インターフェースを実装した抽象クラスを書いてみる。
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 |
namespace Skelton { using System; using System.ComponentModel; /// <summary> /// プロパティ変更通知を持つデータの抽象クラス /// </summary> public abstract class PropertyChangedDataClassBase : INotifyPropertyChanged, IDisposable { #region INotifyPropertyChanged の実装 /// <summary>変更イベントハンドラ /// プロパティ値 /// </summary> private PropertyChangedEventHandler propertyChangedHandler; /// <summary> /// プロパティ値変更イベント /// </summary> public event PropertyChangedEventHandler PropertyChanged { add { propertyChangedHandler += value; } remove { propertyChangedHandler -= value; } } /// <summary> /// プロパティ値変更通知 /// </summary> /// <param name="propertyName"></param> protected virtual void RaisePropertyChanged(string propertyName) { var h = propertyChangedHandler; if (h != null) h(this, new PropertyChangedEventArgs(propertyName)); } /// <summary> /// プロパティ値変更ヘルパー /// </summary> /// <typeparam name="T"></typeparam> /// <param name="target">変更するターゲット変数</param> /// <param name="value">変更後の値</param> /// <param name="propertyName">プロパティ名</param> /// <returns>false:変更なし/true:変更あり</returns> public virtual bool SetProperty<T>(ref T target, T value, string propertyName) { if (target == null) { if (value == null) return false; } else { if (target.Equals(value)) return false; } target = value; RaisePropertyChanged(propertyName); return true; } #endregion #region IDisposable の実装 /// <summary> /// リソース解放済みか確認する /// </summary> public bool IsDisposed { get; private set; } /// <summary> /// リソースの解放 /// </summary> public void Dispose() { try { OnDispose(true); } catch { } } /// <summary> /// リソースの解放処理 /// </summary> /// <param name="disposeAll"></param> protected virtual void OnDispose(bool disposeAll) { if (IsDisposed) return; IsDisposed = true; if (disposeAll) { // マネージドなリソースの解放 foreach (PropertyChangedEventHandler h in propertyChangedHandler.GetInvocationList()) { PropertyChanged -= h; } } // アンマネージドなリソースの解放 (override で記述) } #endregion } } |
きれ … Continue reading