view +multiblock/Surface.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 24b2487b01c2
children
line wrap: on
line source

classdef Surface < handle
    properties
        grid
        surfs

        ZData
        CData

    end

    methods
        function obj = Surface(g, gf)
            obj.grid = g;

            coords = obj.grid.points();
            X = obj.grid.funcToPlotMatrices(coords(:,1));
            Y = obj.grid.funcToPlotMatrices(coords(:,2));

            V = obj.grid.funcToPlotMatrices(gf);


            holdState = ishold();
            hold on

            surfs = cell(1, obj.grid.nBlocks);
            for i = 1:obj.grid.nBlocks
                surfs{i} = surf(X{i}, Y{i}, V{i});
            end

            if holdState == false
                hold off
            end

            obj.surfs = [surfs{:}];

            obj.ZData = gf;
            obj.CData = gf;
        end

        function set(obj, propertyName, propertyValue)
            set(obj.surfs, propertyName, propertyValue);
        end

        function obj = set.ZData(obj, gf)
            obj.ZData = gf;

            V = obj.grid.funcToPlotMatrices(gf);
            for i = 1:obj.grid.nBlocks
                obj.surfs(i).ZData = V{i};
            end
        end

        function obj = set.CData(obj, gf)
            obj.CData = gf;

            V = obj.grid.funcToPlotMatrices(gf);
            for i = 1:obj.grid.nBlocks
                obj.surfs(i).CData = V{i};
            end
        end
    end
end