-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathCategoryTheme.cs
172 lines (149 loc) · 4.31 KB
/
CategoryTheme.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
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
// Copyright 2014 - Felix Obermaier (www.ivv-aachen.de)
//
// This file is part of SharpMap.Rendering.Thematics.CategoryTheme.
// SharpMap.Rendering.Decoration.Legend is free software; you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
//
// SharpMap.Rendering.Thematics.CategoryTheme is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with SharpMap; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
using System;
using System.Collections.Generic;
using System.Diagnostics;
using SharpMap.Data;
using SharpMap.Styles;
namespace SharpMap.Rendering.Thematics
{
///<summary>
///</summary>
[Serializable]
public class CategoryTheme<T> : /*NotificationObject,*/ ITheme
where T: IComparable<T>
{
private readonly List<ICategoryThemeItem<T>> _items = new List<ICategoryThemeItem<T>> ();
private string _columnName;
private bool _sorted;
public bool UseDefaultStyleForDbNull;
/// <summary>
/// Creates an instance of this class setting the default style to a disabled
/// </summary>
public CategoryTheme()
:this(CreateDisabledStyle())
{
}
/// <summary>
/// Creates an instance of this class setting the default style
/// </summary>
/// <param name="style">The default style</param>
public CategoryTheme(IStyle style)
{
_default = style;
}
/// <summary>
/// The column name to get the value from
/// </summary>
public string ColumnName
{
get
{
return _columnName;
}
set
{
if (string.IsNullOrWhiteSpace(value))
throw new ArgumentNullException("value");
if (value.Equals(_columnName))
return;
_columnName = value;
//this.OnPropertyChanged("ColumnName");
}
}
private IStyle _default;
/// <summary>
/// Gets or sets the default <see cref="IStyle"/>, used when the attribute value does not match the criteria
/// </summary>
public IStyle Default
{
get { return _default ?? (_default = CreateDisabledStyle()); }
set
{
_default = value;
//this.OnPropertyChanged("Default");
}
}
private static IStyle CreateDisabledStyle()
{
var res = new VectorStyle();
res.Enabled = false;
return res;
}
///<summary>
///</summary>
///<param name="cti"></param>
public void Add(ICategoryThemeItem<T> cti)
{
_items.Add(cti);
_sorted = false;
//this.OnPropertyChanged("Items");
}
///<summary>
///</summary>
public void Clear()
{
_items.Clear();
//this.OnPropertyChanged("Items");
}
/// <summary>
/// Method to evaluate the style
/// </summary>
public IStyle GetStyle(FeatureDataRow attribute)
{
Debug.Assert(!String.IsNullOrEmpty(_columnName));
Debug.Assert(_default != null);
if (attribute == null)
throw new ArgumentNullException("attribute", "The attribute row must not be null!");
// If the row has no value return the default style
if (attribute.IsNull(_columnName))
return UseDefaultStyleForDbNull ? _default : null;
// Sort the list
if (!_sorted)
{
_items.Sort();
_sorted = true;
}
object val = attribute[_columnName];
if (val is T)
{
var tval = (T)val;
try
{
var cti = _items.Find(c => c.Matches(tval));
return cti.Style;
}
catch(NullReferenceException)
{
}
//foreach (ICategoryThemeItem<T> categoryThemeItem in _items)
//{
// if (categoryThemeItem.Matches(tval)) return categoryThemeItem.Style;
//}
}
return _default;
}
/// <summary>
/// Method to expose all <see cref="ICategoryThemeItem{T}"/>s.
/// </summary>
/// <returns></returns>
public System.Collections.ObjectModel.ReadOnlyCollection<ICategoryThemeItem<T>> ItemsAsReadOnly()
{
return _items.AsReadOnly();
}
}
}