examples/chart_pie.rb in write_xlsx-0.62.0 vs examples/chart_pie.rb in write_xlsx-0.64.0

- old
+ new

@@ -3,10 +3,16 @@ ####################################################################### # # A demo of a Pie chart in Excel::Writer::XLSX. # +# The demo also shows how to set segment colours. It is possible to +# define chart colors for most types of WrtieXLSX charts +# via the add_series() method. However, Pie charts are a special case +# since each segment is represented as a point so it is necessary to +# assign formatting to each point in the series. +# # reverse(c), March 2011, John McNamara, jmcnamara@cpan.org # convert to ruby by Hideo NAKAMURA, cxn03651@msj.biglobe.ne.jp # require 'rubygems' @@ -25,25 +31,50 @@ worksheet.write('A1', headings, bold) worksheet.write('A2', data) # Create a new chart object. In this case an embedded chart. -chart = workbook.add_chart(:type => 'pie', :embedded => 1) +chart1 = workbook.add_chart(:type => 'pie', :embedded => 1) # Configure the series. Note the use of the array ref to define ranges: # [ $sheetname, $row_start, $row_end, $col_start, $col_end ]. -chart.add_series( +# See below for an alternative syntax. +chart1.add_series( :name => 'Pie sales data', :categories => [ 'Sheet1', 1, 3, 0, 0 ], :values => [ 'Sheet1', 1, 3, 1, 1 ] ) # Add a title. -chart.set_title(:name => 'Popular Pie Types') +chart1.set_title(:name => 'Popular Pie Types') # Set an Excel chart style. Blue colors with white outline and shadow. -chart.set_style(10) +chart1.set_style(10) # Insert the chart into the worksheet (with an offset). -worksheet.insert_chart('C2', chart, 25, 10) +worksheet.insert_chart('C2', chart1, 25, 10) + +# +# Create a Pie chart with user defined segment colors. +# + +# Create an example Pie chart like above. +chart2 = workbook.add_chart(:type => 'pie', :embedded => 1) + +# Configure the series and add user defined segment colours. +chart2.add_series( + :name => 'Pie sales data', + :categories => '=Sheet1!$A$2:$A$4', + :values => '=Sheet1!$B$2:$B$4', + :points => [ + { :fill => { :color => '#5ABA10' } }, + { :fill => { :color => '#FE110E' } }, + { :fill => { :color => '#CA5C05' } } + ] + ) + +# Add a title. +chart2.set_title(:name => 'Pie Chart with user defined colors') + +worksheet.insert_chart('C18', chart2, 25, 10) workbook.close