2 // System.Drawing.StringFormat.cs
5 // Dennis Hayes (dennish@Raytek.com)
6 // Miguel de Icaza (miguel@ximian.com)
7 // Jordi Mas i Hernandez (jordi@ximian.com)
9 // Copyright (C) 2002 Ximian, Inc (http://www.ximian.com)
10 // Copyright (C) 2004,2006 Novell, Inc (http://www.novell.com)
12 // Permission is hereby granted, free of charge, to any person obtaining
13 // a copy of this software and associated documentation files (the
14 // "Software"), to deal in the Software without restriction, including
15 // without limitation the rights to use, copy, modify, merge, publish,
16 // distribute, sublicense, and/or sell copies of the Software, and to
17 // permit persons to whom the Software is furnished to do so, subject to
18 // the following conditions:
20 // The above copyright notice and this permission notice shall be
21 // included in all copies or substantial portions of the Software.
23 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
24 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
25 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
26 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
27 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
28 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
29 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
32 using System.ComponentModel;
33 using System.Drawing.Text;
35 namespace System.Drawing {
37 public sealed class StringFormat : MarshalByRefObject, IDisposable, ICloneable
39 private static StringFormat genericDefault;
40 private IntPtr nativeStrFmt = IntPtr.Zero;
41 private int language = GDIPlus.LANG_NEUTRAL;
43 public StringFormat() : this (0, GDIPlus.LANG_NEUTRAL)
47 public StringFormat(StringFormatFlags options, int lang)
49 Status status = GDIPlus.GdipCreateStringFormat (options, lang, out nativeStrFmt);
50 GDIPlus.CheckStatus (status);
53 internal StringFormat(IntPtr native)
55 nativeStrFmt = native;
63 public void Dispose ()
66 System.GC.SuppressFinalize (this);
69 void Dispose (bool disposing)
71 if (nativeStrFmt != IntPtr.Zero) {
72 Status status = GDIPlus.GdipDeleteStringFormat (nativeStrFmt);
73 GDIPlus.CheckStatus (status);
75 nativeStrFmt = IntPtr.Zero;
79 public StringFormat (StringFormat source)
82 throw new ArgumentNullException ("source");
84 Status status = GDIPlus.GdipCloneStringFormat (source.NativeObject, out nativeStrFmt);
85 GDIPlus.CheckStatus (status);
88 public StringFormat (StringFormatFlags flags)
90 Status status = GDIPlus.GdipCreateStringFormat (flags, GDIPlus.LANG_NEUTRAL, out nativeStrFmt);
91 GDIPlus.CheckStatus (status);
94 public StringAlignment Alignment {
96 StringAlignment align;
97 Status status = GDIPlus.GdipGetStringFormatAlign (nativeStrFmt, out align);
98 GDIPlus.CheckStatus (status);
104 if ((value < StringAlignment.Near) || (value > StringAlignment.Far))
105 throw new InvalidEnumArgumentException ("Alignment");
107 Status status = GDIPlus.GdipSetStringFormatAlign (nativeStrFmt, value);
108 GDIPlus.CheckStatus (status);
112 public StringAlignment LineAlignment {
114 StringAlignment align;
115 Status status = GDIPlus.GdipGetStringFormatLineAlign (nativeStrFmt, out align);
116 GDIPlus.CheckStatus (status);
122 if ((value < StringAlignment.Near) || (value > StringAlignment.Far))
123 throw new InvalidEnumArgumentException ("Alignment");
125 Status status = GDIPlus.GdipSetStringFormatLineAlign (nativeStrFmt, value);
126 GDIPlus.CheckStatus (status);
130 public StringFormatFlags FormatFlags {
132 StringFormatFlags flags;
133 Status status = GDIPlus.GdipGetStringFormatFlags (nativeStrFmt, out flags);
134 GDIPlus.CheckStatus (status);
140 Status status = GDIPlus.GdipSetStringFormatFlags (nativeStrFmt, value);
141 GDIPlus.CheckStatus (status);
145 public HotkeyPrefix HotkeyPrefix {
147 HotkeyPrefix hotkeyPrefix;
148 Status status = GDIPlus.GdipGetStringFormatHotkeyPrefix (nativeStrFmt, out hotkeyPrefix);
149 GDIPlus.CheckStatus (status);
155 if ((value < HotkeyPrefix.None) || (value > HotkeyPrefix.Hide))
156 throw new InvalidEnumArgumentException ("HotkeyPrefix");
158 Status status = GDIPlus.GdipSetStringFormatHotkeyPrefix (nativeStrFmt, value);
159 GDIPlus.CheckStatus (status);
164 public StringTrimming Trimming {
166 StringTrimming trimming;
167 Status status = GDIPlus.GdipGetStringFormatTrimming (nativeStrFmt, out trimming);
168 GDIPlus.CheckStatus (status);
173 if ((value < StringTrimming.None) || (value > StringTrimming.EllipsisPath))
174 throw new InvalidEnumArgumentException ("Trimming");
176 Status status = GDIPlus.GdipSetStringFormatTrimming (nativeStrFmt, value);
177 GDIPlus.CheckStatus (status);
181 public static StringFormat GenericDefault {
185 Status status = GDIPlus.GdipStringFormatGetGenericDefault (out ptr);
186 GDIPlus.CheckStatus (status);
188 return new StringFormat (ptr);
193 public int DigitSubstitutionLanguage {
200 public static StringFormat GenericTypographic {
204 Status status = GDIPlus.GdipStringFormatGetGenericTypographic (out ptr);
205 GDIPlus.CheckStatus (status);
207 return new StringFormat (ptr);
211 public StringDigitSubstitute DigitSubstitutionMethod {
213 StringDigitSubstitute substitute;
215 Status status = GDIPlus.GdipGetStringFormatDigitSubstitution(nativeStrFmt, language, out substitute);
216 GDIPlus.CheckStatus (status);
223 public void SetMeasurableCharacterRanges (CharacterRange [] range)
225 Status status = GDIPlus.GdipSetStringFormatMeasurableCharacterRanges (nativeStrFmt,
226 range.Length, range);
228 GDIPlus.CheckStatus (status);
231 internal int GetMeasurableCharacterRangeCount ()
234 Status status = GDIPlus.GdipGetStringFormatMeasurableCharacterRangeCount (nativeStrFmt, out cnt);
236 GDIPlus.CheckStatus (status);
240 public object Clone()
244 Status status = GDIPlus.GdipCloneStringFormat (nativeStrFmt, out native);
245 GDIPlus.CheckStatus (status);
247 return new StringFormat (native);
250 public override string ToString()
252 return "[StringFormat, FormatFlags=" + this.FormatFlags.ToString() + "]";
255 internal IntPtr NativeObject
261 nativeStrFmt = value;
265 public void SetTabStops(float firstTabOffset, float[] tabStops)
267 Status status = GDIPlus.GdipSetStringFormatTabStops(nativeStrFmt, firstTabOffset, tabStops.Length, tabStops);
268 GDIPlus.CheckStatus (status);
271 public void SetDigitSubstitution(int language, StringDigitSubstitute substitute)
273 Status status = GDIPlus.GdipSetStringFormatDigitSubstitution(nativeStrFmt, this.language, substitute);
274 GDIPlus.CheckStatus (status);
277 public float[] GetTabStops(out float firstTabOffset)
282 Status status = GDIPlus.GdipGetStringFormatTabStopCount(nativeStrFmt, out count);
283 GDIPlus.CheckStatus (status);
285 float[] tabStops = new float[count];
288 status = GDIPlus.GdipGetStringFormatTabStops(nativeStrFmt, count, out firstTabOffset, tabStops);
289 GDIPlus.CheckStatus (status);