Well, let's just get right in to the code.
The controller contains the same code as my last post with only a few minor changes to the index method and the addition of the upload_image method.
In the controller, I have this:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
class TestItController < ApplicationController def index # note the user of open_flash_chart_object_from_hash instead of just open_flash_chart_object # this allows you to pass in the id of the div you want the the chart to be in # this is useful for when we need to findSWF by this id @graph = open_flash_chart_object_from_hash("/test_it/chart", :div_name => "my_chart") end # added to recieve the post data for the OFC png image of the OFC graph def upload_image name = "tmp_image.png" || params[:name] # the save_image method that is provided by the OFC swf file sends raw post data, so get to it like this data = request.raw_post File.open("#{RAILS_ROOT}/tmp/#{name}", "wb") { |f| f.write(data) } if data render :nothing => true end def chart # same code from here - http://pullmonkey.com/2010/01/05/open-flash-chart-ii-x-axis-date-and-time/ ... end end |
So just note the use of open_flash_chart_object_from_hash() in the index method, this way we can pass in the id of the div.
In the view, I have this:
1 2 3 4 5 |
<%= javascript_include_tag 'swfobject.js' %> <%= @graph %> <%= save_as_image("http://localhost:3000/test_it/upload_image?name=tmp.png", :id => "my_chart") %> <br/> <%= button_to_function "Save Image", "post_image()" %> |
Really the only difference from what we would normally have in our view is that I am using the save image setup method that was added to the open flash chart ruby on rails plugin in the last couple hours (as of this post). The save_image method takes some arguments, mainly the url to post the image data to and the id of the chart we setup in the controller.
]]>