Mercurial > repos > public > sbplib
view +anim/setup_1d_plot.m @ 577:e45c9b56d50d feature/grids
Add an Empty grid class
The need turned up for the flexural code when we may or may not have a grid for the open water and want to plot that solution.
In case there is no open water we need an empty grid to plot the empty gridfunction against to avoid errors.
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Thu, 07 Sep 2017 09:16:12 +0200 |
parents | df83c8095326 |
children |
line wrap: on
line source
% Creates a plot and provides a function to update the data in it. % x - Vector of x-values to plot for. % y_lim - 1x2 vector containing the y limits of the plot. % yfun - Function or a cell array of functions of y data vectors % that should be plotted. The output of each function % will be plotted to the same axis. % % update_data(t,varargin) - Function to update plot data. All varargin will % be passed to functions in yfun. % plot_handles - Array of plot_handles. One for each yfun. % axis_handle - Handle to the axis plotted to. function [update_data, plot_handles, axis_handle] = setup_1d_plot(x,yfun,show_title) default_arg('yfun',{@(y)y}); default_arg('show_title', true) if isa(yfun,'function_handle') yfun = {yfun}; end figure_handle = gcf; plot_handles(1) = plot(x,0*x); for i = 2:length(yfun) plot_handles(i) = line(x,0*x); end axis_handle = gca; xlim([x(1) x(end)]); function update(t,varargin) if ishandle(figure_handle) && ishandle(axis_handle) for i = 1:length(yfun) set(plot_handles(i),'YData',yfun{i}(varargin{:})); end if show_title title(axis_handle,sprintf('T=%.3f',t)); end end end update_data = @update; end