writeexcel 0.5.0 → 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (130) hide show
  1. data/.gitattributes +1 -1
  2. data/.gitignore +24 -24
  3. data/README.rdoc +34 -55
  4. data/VERSION +1 -1
  5. data/charts/chartex.rb +316 -316
  6. data/charts/demo1.rb +46 -46
  7. data/charts/demo2.rb +65 -65
  8. data/charts/demo3.rb +117 -117
  9. data/charts/demo4.rb +119 -119
  10. data/charts/demo5.rb +48 -48
  11. data/examples/a_simple.rb +43 -43
  12. data/examples/autofilter.rb +265 -265
  13. data/examples/bigfile.rb +30 -30
  14. data/examples/chart_area.rb +121 -121
  15. data/examples/chart_bar.rb +120 -120
  16. data/examples/chart_column.rb +120 -120
  17. data/examples/chart_line.rb +120 -120
  18. data/examples/chart_pie.rb +108 -108
  19. data/examples/chart_scatter.rb +121 -121
  20. data/examples/chart_stock.rb +148 -148
  21. data/examples/chess.rb +142 -142
  22. data/examples/colors.rb +129 -129
  23. data/examples/comments1.rb +27 -27
  24. data/examples/comments2.rb +352 -352
  25. data/examples/copyformat.rb +52 -52
  26. data/examples/data_validate.rb +279 -279
  27. data/examples/date_time.rb +87 -87
  28. data/examples/defined_name.rb +32 -32
  29. data/examples/demo.rb +124 -124
  30. data/examples/diag_border.rb +36 -36
  31. data/examples/formats.rb +490 -490
  32. data/examples/formula_result.rb +30 -30
  33. data/examples/header.rb +137 -137
  34. data/examples/hide_sheet.rb +29 -29
  35. data/examples/hyperlink.rb +43 -43
  36. data/examples/images.rb +63 -63
  37. data/examples/indent.rb +31 -31
  38. data/examples/merge1.rb +40 -40
  39. data/examples/merge2.rb +45 -45
  40. data/examples/merge3.rb +66 -66
  41. data/examples/merge4.rb +83 -83
  42. data/examples/merge5.rb +80 -80
  43. data/examples/merge6.rb +67 -67
  44. data/examples/outline.rb +255 -255
  45. data/examples/outline_collapsed.rb +209 -209
  46. data/examples/panes.rb +113 -113
  47. data/examples/properties.rb +34 -34
  48. data/examples/properties_jp.rb +33 -33
  49. data/examples/protection.rb +47 -47
  50. data/examples/regions.rb +53 -53
  51. data/examples/repeat.rb +43 -43
  52. data/examples/right_to_left.rb +27 -27
  53. data/examples/row_wrap.rb +53 -53
  54. data/examples/stats.rb +74 -74
  55. data/examples/stocks.rb +81 -81
  56. data/examples/tab_colors.rb +31 -31
  57. data/examples/utf8.rb +15 -15
  58. data/examples/write_arrays.rb +83 -83
  59. data/lib/writeexcel/biffwriter.rb +232 -232
  60. data/lib/writeexcel/caller_info.rb +12 -12
  61. data/lib/writeexcel/chart.rb +2190 -2177
  62. data/lib/writeexcel/charts/area.rb +154 -154
  63. data/lib/writeexcel/charts/bar.rb +177 -177
  64. data/lib/writeexcel/charts/column.rb +156 -156
  65. data/lib/writeexcel/charts/external.rb +66 -66
  66. data/lib/writeexcel/charts/line.rb +154 -154
  67. data/lib/writeexcel/charts/pie.rb +169 -169
  68. data/lib/writeexcel/charts/scatter.rb +192 -192
  69. data/lib/writeexcel/charts/stock.rb +213 -213
  70. data/lib/writeexcel/colors.rb +64 -64
  71. data/lib/writeexcel/compatibility.rb +0 -255
  72. data/lib/writeexcel/debug_info.rb +37 -33
  73. data/lib/writeexcel/excelformulaparser.rb +587 -587
  74. data/lib/writeexcel/format.rb +13 -4
  75. data/lib/writeexcel/formula.rb +26 -9
  76. data/lib/writeexcel/helper.rb +68 -64
  77. data/lib/writeexcel/olewriter.rb +311 -311
  78. data/lib/writeexcel/properties.rb +242 -240
  79. data/lib/writeexcel/storage_lite.rb +984 -978
  80. data/lib/writeexcel/workbook.rb +3210 -3192
  81. data/lib/writeexcel/worksheet.rb +143 -51
  82. data/lib/writeexcel/write_file.rb +44 -40
  83. data/lib/writeexcel.rb +1159 -1159
  84. data/test/helper.rb +31 -28
  85. data/test/perl_output/README +31 -31
  86. data/test/test_00_IEEE_double.rb +13 -13
  87. data/test/test_01_add_worksheet.rb +10 -10
  88. data/test/test_02_merge_formats.rb +53 -53
  89. data/test/test_04_dimensions.rb +392 -392
  90. data/test/test_05_rows.rb +179 -179
  91. data/test/test_06_extsst.rb +77 -77
  92. data/test/test_11_date_time.rb +479 -479
  93. data/test/test_12_date_only.rb +501 -501
  94. data/test/test_13_date_seconds.rb +481 -481
  95. data/test/test_21_escher.rb +637 -637
  96. data/test/test_22_mso_drawing_group.rb +745 -745
  97. data/test/test_23_note.rb +73 -73
  98. data/test/test_24_txo.rb +75 -75
  99. data/test/test_25_position_object.rb +84 -84
  100. data/test/test_26_autofilter.rb +314 -314
  101. data/test/test_27_autofilter.rb +131 -131
  102. data/test/test_28_autofilter.rb +161 -161
  103. data/test/test_29_process_jpg.rb +683 -683
  104. data/test/test_30_validation_dval.rb +77 -77
  105. data/test/test_31_validation_dv_strings.rb +126 -126
  106. data/test/test_32_validation_dv_formula.rb +206 -206
  107. data/test/test_40_property_types.rb +188 -188
  108. data/test/test_41_properties.rb +235 -235
  109. data/test/test_42_set_properties.rb +437 -437
  110. data/test/test_50_name_stored.rb +299 -299
  111. data/test/test_51_name_print_area.rb +357 -357
  112. data/test/test_52_name_print_titles.rb +454 -454
  113. data/test/test_53_autofilter.rb +203 -203
  114. data/test/test_60_chart_generic.rb +578 -578
  115. data/test/test_61_chart_subclasses.rb +95 -95
  116. data/test/test_62_chart_formats.rb +272 -272
  117. data/test/test_63_chart_area_formats.rb +649 -649
  118. data/test/test_biff.rb +75 -75
  119. data/test/test_compatibility.rb +12 -627
  120. data/test/test_example_match.rb +3144 -3144
  121. data/test/test_formula.rb +61 -61
  122. data/test/test_ole.rb +106 -106
  123. data/test/test_storage_lite.rb +125 -125
  124. data/test/test_workbook.rb +139 -139
  125. data/test/test_worksheet.rb +110 -110
  126. data/utils/add_magic_comment.rb +80 -80
  127. data/writeexcel.gemspec +4 -6
  128. data/writeexcel.rdoc +58 -15
  129. metadata +9 -6
  130. data/test/test_new_encoding.rb +0 -205
@@ -1,213 +1,213 @@
1
- # -*- coding: utf-8 -*-
2
- ###############################################################################
3
- #
4
- # Stock - A writer class for Excel Stock charts.
5
- #
6
- # Used in conjunction with Spreadsheet::WriteExcel::Chart.
7
- #
8
- # See formatting note in Spreadsheet::WriteExcel::Chart.
9
- #
10
- # Copyright 2000-2010, John McNamara, jmcnamara@cpan.org
11
- #
12
- # original written in Perl by John McNamara
13
- # converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
14
- #
15
-
16
- require 'writeexcel'
17
-
18
- module Writeexcel
19
-
20
- class Chart
21
-
22
- # ==SYNOPSIS
23
- #
24
- # To create a simple Excel file with a Stock chart using WriteExcel:
25
- #
26
- # #!/usr/bin/ruby -w
27
- #
28
- # require 'writeexcel'
29
- #
30
- # workbook = Spreadsheet::WriteExcel.new('chart.xls')
31
- # worksheet = workbook.add_worksheet
32
- #
33
- # chart = workbook.add_chart(:type => 'Chart::Stock')
34
- #
35
- # # Add a series for each Open-High-Low-Close.
36
- # chart.add_series(:categories => '=Sheet1!$A$2:$A$6', :values => '=Sheet1!$B$2:$B$6')
37
- # chart.add_series(:categories => '=Sheet1!$A$2:$A$6', :values => '=Sheet1!$C$2:$C$6')
38
- # chart.add_series(:categories => '=Sheet1!$A$2:$A$6', :values => '=Sheet1!$D$2:$D$6')
39
- # chart.add_series(:categories => '=Sheet1!$A$2:$A$6', :values => '=Sheet1!$E$2:$E$6')
40
- #
41
- # # Add the worksheet data the chart refers to.
42
- # # ... See the full example below.
43
- #
44
- # workbook.close
45
- #
46
- # ==DESCRIPTION
47
- #
48
- # This module implements Stock charts for WriteExcel. The chart object
49
- # is created via the Workbook add_chart() method:
50
- #
51
- # chart = workbook.add_chart(:type => 'Chart::Stock')
52
- #
53
- # Once the object is created it can be configured via the following methods
54
- # that are common to all chart classes:
55
- #
56
- # chart.add_series
57
- # chart.set_x_axis
58
- # chart.set_y_axis
59
- # chart.set_title
60
- #
61
- # These methods are explained in detail in Chart section of WriteExcel.
62
- # Class specific methods or settings, if any, are explained below.
63
- #
64
- # ==Stock Chart Methods
65
- #
66
- # There aren't currently any stock chart specific methods.
67
- # See the TODO section of Chart section in WriteExcel.
68
- #
69
- # The default Stock chart is an Open-High-Low-Close chart.
70
- # A series must be added for each of these data sources.
71
- #
72
- # The default Stock chart is in black and white. User defined colours
73
- # will be added at a later stage.
74
- #
75
- # ==EXAMPLE
76
- #
77
- # Here is a complete example that demonstrates most of the available features
78
- # when creating a Stock chart.
79
- #
80
- # #!/usr/bin/ruby -w
81
- #
82
- # require 'writeexcel'
83
- #
84
- # workbook = Spreadsheet::WriteExcel.new('chart_stock_ex.xls')
85
- # worksheet = workbook.add_worksheet
86
- # bold = workbook.add_format(:bold => 1)
87
- # date_format = workbook.add_format(:num_format => 'dd/mm/yyyy')
88
- #
89
- # # Add the worksheet data that the charts will refer to.
90
- # headings = [ 'Date', 'Open', 'High', 'Low', 'Close' ]
91
- # data = [
92
- # [ '2009-08-23', 110.75, 113.48, 109.05, 109.40 ],
93
- # [ '2009-08-24', 111.24, 111.60, 103.57, 104.87 ],
94
- # [ '2009-08-25', 104.96, 108.00, 103.88, 106.00 ],
95
- # [ '2009-08-26', 104.95, 107.95, 104.66, 107.91 ],
96
- # [ '2009-08-27', 108.10, 108.62, 105.69, 106.15 ]
97
- # ]
98
- #
99
- # worksheet.write('A1', headings, bold)
100
- #
101
- # row = 1
102
- # data.each do |d|
103
- # worksheet.write(row, 0, d[0], date_format)
104
- # worksheet.write(row, 1, d[1])
105
- # worksheet.write(row, 2, d[2])
106
- # worksheet.write(row, 3, d[3])
107
- # worksheet.write(row, 4, d[4])
108
- # row += 1
109
- # end
110
- #
111
- # # Create a new chart object. In this case an embedded chart.
112
- # chart = workbook.add_chart(:type => 'Chart::Stock', ::embedded => 1)
113
- #
114
- # # Add a series for each of the Open-High-Low-Close columns.
115
- # chart.add_series(
116
- # :categories => '=Sheet1!$A$2:$A$6',
117
- # :values => '=Sheet1!$B$2:$B$6',
118
- # :name => 'Open'
119
- # )
120
- #
121
- # chart.add_series(
122
- # :categories => '=Sheet1!$A$2:$A$6',
123
- # :values => '=Sheet1!$C$2:$C$6',
124
- # :name => 'High'
125
- # )
126
- #
127
- # chart.add_series(
128
- # :categories => '=Sheet1!$A$2:$A$6',
129
- # :values => '=Sheet1!$D$2:$D$6',
130
- # :name => 'Low'
131
- # )
132
- #
133
- # chart.add_series(
134
- # :categories => '=Sheet1!$A$2:$A$6',
135
- # :values => '=Sheet1!$E$2:$E$6',
136
- # :name => 'Close'
137
- # )
138
- #
139
- # # Add a chart title and some axis labels.
140
- # chart.set_title(:name => 'Open-High-Low-Close')
141
- # chart.set_x_axis(:name => 'Date')
142
- # chart.set_y_axis(:name => 'Share price')
143
- #
144
- # # Insert the chart into the worksheet (with an offset).
145
- # worksheet.insert_chart('F2', chart, 25, 10)
146
- #
147
- # workbook.close
148
- #
149
- class Stock < Chart
150
- ###############################################################################
151
- #
152
- # new()
153
- #
154
- #
155
- def initialize(*args) # :nodoc:
156
- super
157
- end
158
-
159
- ###############################################################################
160
- #
161
- # _store_chart_type()
162
- #
163
- # Implementation of the abstract method from the specific chart class.
164
- #
165
- # Write the LINE chart BIFF record. A stock chart uses the same LINE record
166
- # as a line chart but with additional DROPBAR and CHARTLINE records to define
167
- # the stock style.
168
- #
169
- def store_chart_type # :nodoc:
170
- record = 0x1018 # Record identifier.
171
- length = 0x0002 # Number of bytes to follow.
172
- grbit = 0x0000 # Option flags.
173
-
174
- store_simple(record, length, grbit)
175
- end
176
-
177
- ###############################################################################
178
- #
179
- # _store_marker_dataformat_stream(). Overridden.
180
- #
181
- # This is an implementation of the parent abstract method to define
182
- # properties of markers, linetypes, pie formats and other.
183
- #
184
- def store_marker_dataformat_stream # :nodoc:
185
- store_dropbar
186
- store_begin
187
- store_lineformat(0x00000000, 0x0000, 0xFFFF, 0x0001, 0x004F)
188
- store_areaformat(0x00FFFFFF, 0x0000, 0x01, 0x01, 0x09, 0x08)
189
- store_end
190
-
191
- store_dropbar
192
- store_begin
193
- store_lineformat(0x00000000, 0x0000, 0xFFFF, 0x0001, 0x004F)
194
- store_areaformat(0x0000, 0x00FFFFFF, 0x01, 0x01, 0x08, 0x09)
195
- store_end
196
-
197
- store_chartline
198
- store_lineformat(0x00000000, 0x0000, 0xFFFF, 0x0000, 0x004F)
199
-
200
-
201
- store_dataformat(0x0000, 0xFFFD, 0x0000)
202
- store_begin
203
- store_3dbarshape
204
- store_lineformat(0x00000000, 0x0005, 0xFFFF, 0x0000, 0x004F)
205
- store_areaformat(0x00000000, 0x0000, 0x00, 0x01, 0x4D, 0x4D)
206
- store_pieformat
207
- store_markerformat(0x00, 0x00, 0x00, 0x00, 0x4D, 0x4D, 0x3C)
208
- store_end
209
- end
210
- end
211
- end # class Chart
212
-
213
- end # module Writeexcel
1
+ # -*- coding: utf-8 -*-
2
+ ###############################################################################
3
+ #
4
+ # Stock - A writer class for Excel Stock charts.
5
+ #
6
+ # Used in conjunction with WriteExcel::Chart.
7
+ #
8
+ # See formatting note in WriteExcel::Chart.
9
+ #
10
+ # Copyright 2000-2010, John McNamara, jmcnamara@cpan.org
11
+ #
12
+ # original written in Perl by John McNamara
13
+ # converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
14
+ #
15
+
16
+ require 'writeexcel'
17
+
18
+ module Writeexcel
19
+
20
+ class Chart
21
+
22
+ # ==SYNOPSIS
23
+ #
24
+ # To create a simple Excel file with a Stock chart using WriteExcel:
25
+ #
26
+ # #!/usr/bin/ruby -w
27
+ #
28
+ # require 'writeexcel'
29
+ #
30
+ # workbook = WriteExcel.new('chart.xls')
31
+ # worksheet = workbook.add_worksheet
32
+ #
33
+ # chart = workbook.add_chart(:type => 'Chart::Stock')
34
+ #
35
+ # # Add a series for each Open-High-Low-Close.
36
+ # chart.add_series(:categories => '=Sheet1!$A$2:$A$6', :values => '=Sheet1!$B$2:$B$6')
37
+ # chart.add_series(:categories => '=Sheet1!$A$2:$A$6', :values => '=Sheet1!$C$2:$C$6')
38
+ # chart.add_series(:categories => '=Sheet1!$A$2:$A$6', :values => '=Sheet1!$D$2:$D$6')
39
+ # chart.add_series(:categories => '=Sheet1!$A$2:$A$6', :values => '=Sheet1!$E$2:$E$6')
40
+ #
41
+ # # Add the worksheet data the chart refers to.
42
+ # # ... See the full example below.
43
+ #
44
+ # workbook.close
45
+ #
46
+ # ==DESCRIPTION
47
+ #
48
+ # This module implements Stock charts for WriteExcel. The chart object
49
+ # is created via the Workbook add_chart() method:
50
+ #
51
+ # chart = workbook.add_chart(:type => 'Chart::Stock')
52
+ #
53
+ # Once the object is created it can be configured via the following methods
54
+ # that are common to all chart classes:
55
+ #
56
+ # chart.add_series
57
+ # chart.set_x_axis
58
+ # chart.set_y_axis
59
+ # chart.set_title
60
+ #
61
+ # These methods are explained in detail in Chart section of WriteExcel.
62
+ # Class specific methods or settings, if any, are explained below.
63
+ #
64
+ # ==Stock Chart Methods
65
+ #
66
+ # There aren't currently any stock chart specific methods.
67
+ # See the TODO section of Chart section in WriteExcel.
68
+ #
69
+ # The default Stock chart is an Open-High-Low-Close chart.
70
+ # A series must be added for each of these data sources.
71
+ #
72
+ # The default Stock chart is in black and white. User defined colours
73
+ # will be added at a later stage.
74
+ #
75
+ # ==EXAMPLE
76
+ #
77
+ # Here is a complete example that demonstrates most of the available features
78
+ # when creating a Stock chart.
79
+ #
80
+ # #!/usr/bin/ruby -w
81
+ #
82
+ # require 'writeexcel'
83
+ #
84
+ # workbook = WriteExcel.new('chart_stock_ex.xls')
85
+ # worksheet = workbook.add_worksheet
86
+ # bold = workbook.add_format(:bold => 1)
87
+ # date_format = workbook.add_format(:num_format => 'dd/mm/yyyy')
88
+ #
89
+ # # Add the worksheet data that the charts will refer to.
90
+ # headings = [ 'Date', 'Open', 'High', 'Low', 'Close' ]
91
+ # data = [
92
+ # [ '2009-08-23', 110.75, 113.48, 109.05, 109.40 ],
93
+ # [ '2009-08-24', 111.24, 111.60, 103.57, 104.87 ],
94
+ # [ '2009-08-25', 104.96, 108.00, 103.88, 106.00 ],
95
+ # [ '2009-08-26', 104.95, 107.95, 104.66, 107.91 ],
96
+ # [ '2009-08-27', 108.10, 108.62, 105.69, 106.15 ]
97
+ # ]
98
+ #
99
+ # worksheet.write('A1', headings, bold)
100
+ #
101
+ # row = 1
102
+ # data.each do |d|
103
+ # worksheet.write(row, 0, d[0], date_format)
104
+ # worksheet.write(row, 1, d[1])
105
+ # worksheet.write(row, 2, d[2])
106
+ # worksheet.write(row, 3, d[3])
107
+ # worksheet.write(row, 4, d[4])
108
+ # row += 1
109
+ # end
110
+ #
111
+ # # Create a new chart object. In this case an embedded chart.
112
+ # chart = workbook.add_chart(:type => 'Chart::Stock', ::embedded => 1)
113
+ #
114
+ # # Add a series for each of the Open-High-Low-Close columns.
115
+ # chart.add_series(
116
+ # :categories => '=Sheet1!$A$2:$A$6',
117
+ # :values => '=Sheet1!$B$2:$B$6',
118
+ # :name => 'Open'
119
+ # )
120
+ #
121
+ # chart.add_series(
122
+ # :categories => '=Sheet1!$A$2:$A$6',
123
+ # :values => '=Sheet1!$C$2:$C$6',
124
+ # :name => 'High'
125
+ # )
126
+ #
127
+ # chart.add_series(
128
+ # :categories => '=Sheet1!$A$2:$A$6',
129
+ # :values => '=Sheet1!$D$2:$D$6',
130
+ # :name => 'Low'
131
+ # )
132
+ #
133
+ # chart.add_series(
134
+ # :categories => '=Sheet1!$A$2:$A$6',
135
+ # :values => '=Sheet1!$E$2:$E$6',
136
+ # :name => 'Close'
137
+ # )
138
+ #
139
+ # # Add a chart title and some axis labels.
140
+ # chart.set_title(:name => 'Open-High-Low-Close')
141
+ # chart.set_x_axis(:name => 'Date')
142
+ # chart.set_y_axis(:name => 'Share price')
143
+ #
144
+ # # Insert the chart into the worksheet (with an offset).
145
+ # worksheet.insert_chart('F2', chart, 25, 10)
146
+ #
147
+ # workbook.close
148
+ #
149
+ class Stock < Chart
150
+ ###############################################################################
151
+ #
152
+ # new()
153
+ #
154
+ #
155
+ def initialize(*args) # :nodoc:
156
+ super
157
+ end
158
+
159
+ ###############################################################################
160
+ #
161
+ # _store_chart_type()
162
+ #
163
+ # Implementation of the abstract method from the specific chart class.
164
+ #
165
+ # Write the LINE chart BIFF record. A stock chart uses the same LINE record
166
+ # as a line chart but with additional DROPBAR and CHARTLINE records to define
167
+ # the stock style.
168
+ #
169
+ def store_chart_type # :nodoc:
170
+ record = 0x1018 # Record identifier.
171
+ length = 0x0002 # Number of bytes to follow.
172
+ grbit = 0x0000 # Option flags.
173
+
174
+ store_simple(record, length, grbit)
175
+ end
176
+
177
+ ###############################################################################
178
+ #
179
+ # _store_marker_dataformat_stream(). Overridden.
180
+ #
181
+ # This is an implementation of the parent abstract method to define
182
+ # properties of markers, linetypes, pie formats and other.
183
+ #
184
+ def store_marker_dataformat_stream # :nodoc:
185
+ store_dropbar
186
+ store_begin
187
+ store_lineformat(0x00000000, 0x0000, 0xFFFF, 0x0001, 0x004F)
188
+ store_areaformat(0x00FFFFFF, 0x0000, 0x01, 0x01, 0x09, 0x08)
189
+ store_end
190
+
191
+ store_dropbar
192
+ store_begin
193
+ store_lineformat(0x00000000, 0x0000, 0xFFFF, 0x0001, 0x004F)
194
+ store_areaformat(0x0000, 0x00FFFFFF, 0x01, 0x01, 0x08, 0x09)
195
+ store_end
196
+
197
+ store_chartline
198
+ store_lineformat(0x00000000, 0x0000, 0xFFFF, 0x0000, 0x004F)
199
+
200
+
201
+ store_dataformat(0x0000, 0xFFFD, 0x0000)
202
+ store_begin
203
+ store_3dbarshape
204
+ store_lineformat(0x00000000, 0x0005, 0xFFFF, 0x0000, 0x004F)
205
+ store_areaformat(0x00000000, 0x0000, 0x00, 0x01, 0x4D, 0x4D)
206
+ store_pieformat
207
+ store_markerformat(0x00, 0x00, 0x00, 0x00, 0x4D, 0x4D, 0x3C)
208
+ store_end
209
+ end
210
+ end
211
+ end # class Chart
212
+
213
+ end # module Writeexcel
@@ -1,64 +1,64 @@
1
- # -*- coding: utf-8 -*-
2
-
3
- module Writeexcel
4
-
5
- class Colors
6
- COLORS = {
7
- :aqua => 0x0F,
8
- :cyan => 0x0F,
9
- :black => 0x08,
10
- :blue => 0x0C,
11
- :brown => 0x10,
12
- :magenta => 0x0E,
13
- :fuchsia => 0x0E,
14
- :gray => 0x17,
15
- :grey => 0x17,
16
- :green => 0x11,
17
- :lime => 0x0B,
18
- :navy => 0x12,
19
- :orange => 0x35,
20
- :pink => 0x21,
21
- :purple => 0x14,
22
- :red => 0x0A,
23
- :silver => 0x16,
24
- :white => 0x09,
25
- :yellow => 0x0D,
26
- } # :nodoc:
27
-
28
- ###############################################################################
29
- #
30
- # get_color(colour)
31
- #
32
- # Used in conjunction with the set_xxx_color methods to convert a color
33
- # string into a number. Color range is 0..63 but we will restrict it
34
- # to 8..63 to comply with Gnumeric. Colors 0..7 are repeated in 8..15.
35
- #
36
- def get_color(color = nil) # :nodoc:
37
- if color.respond_to?(:to_int) && color.respond_to?(:+)
38
- # the default color if arg is outside range,
39
- if color < 0 || 63 < color
40
- 0x7FFF
41
- # or an index < 8 mapped into the correct range,
42
- elsif color < 8
43
- (color + 8).to_i
44
- # or an integer in the valid range
45
- else
46
- color.to_i
47
- end
48
- elsif color.respond_to?(:to_sym)
49
- color = color.downcase.to_sym if color.respond_to?(:to_str)
50
- # or the color string converted to an integer,
51
- if COLORS.has_key?(color)
52
- COLORS[color]
53
- # or the default color if string is unrecognised,
54
- else
55
- 0x7FFF
56
- end
57
- else
58
- 0x7FFF
59
- end
60
- end
61
- end # class Colors
62
-
63
- end # module Writeexcel
64
-
1
+ # -*- coding: utf-8 -*-
2
+
3
+ module Writeexcel
4
+
5
+ class Colors
6
+ COLORS = {
7
+ :aqua => 0x0F,
8
+ :cyan => 0x0F,
9
+ :black => 0x08,
10
+ :blue => 0x0C,
11
+ :brown => 0x10,
12
+ :magenta => 0x0E,
13
+ :fuchsia => 0x0E,
14
+ :gray => 0x17,
15
+ :grey => 0x17,
16
+ :green => 0x11,
17
+ :lime => 0x0B,
18
+ :navy => 0x12,
19
+ :orange => 0x35,
20
+ :pink => 0x21,
21
+ :purple => 0x14,
22
+ :red => 0x0A,
23
+ :silver => 0x16,
24
+ :white => 0x09,
25
+ :yellow => 0x0D,
26
+ } # :nodoc:
27
+
28
+ ###############################################################################
29
+ #
30
+ # get_color(colour)
31
+ #
32
+ # Used in conjunction with the set_xxx_color methods to convert a color
33
+ # string into a number. Color range is 0..63 but we will restrict it
34
+ # to 8..63 to comply with Gnumeric. Colors 0..7 are repeated in 8..15.
35
+ #
36
+ def get_color(color = nil) # :nodoc:
37
+ if color.respond_to?(:to_int) && color.respond_to?(:+)
38
+ # the default color if arg is outside range,
39
+ if color < 0 || 63 < color
40
+ 0x7FFF
41
+ # or an index < 8 mapped into the correct range,
42
+ elsif color < 8
43
+ (color + 8).to_i
44
+ # or an integer in the valid range
45
+ else
46
+ color.to_i
47
+ end
48
+ elsif color.respond_to?(:to_sym)
49
+ color = color.downcase.to_sym if color.respond_to?(:to_str)
50
+ # or the color string converted to an integer,
51
+ if COLORS.has_key?(color)
52
+ COLORS[color]
53
+ # or the default color if string is unrecognised,
54
+ else
55
+ 0x7FFF
56
+ end
57
+ else
58
+ 0x7FFF
59
+ end
60
+ end
61
+ end # class Colors
62
+
63
+ end # module Writeexcel
64
+