Стройте диаграмму класса для отображения переменного плиточного размещения размера графиков

В этом примере показано, как задать класс для создания плиточного размещения графиков, которые могут быть любым размером, в зависимости от размера данных пользователя. График имеет общедоступный Data свойство, которое принимает матрицу m на n. График отображает n на n квадратное плиточное размещение графиков рассеивания и гистограмм. Графики рассеивания показывают различные столбцы данных, отображенных на графике друг против друга. Гистограммы показывают распределение значений в рамках каждого столбца данных.

update метод в этом классе воссоздает гистограммы и графики рассеивания, чтобы отразить изменения в данных. Если размер сетки конфликтов размещения с размером данных, то все оси удалены и GridSize свойство обновляется, чтобы совпадать с размером данных. Затем новый набор объектов осей создается.

Чтобы задать класс, скопируйте следующий код в редактор и сохраните его с именем TrellisChart.m в перезаписываемой папке.

classdef TrellisChart < matlab.graphics.chartcontainer.ChartContainer
   
    properties
        Data(:,:) {mustBeNumeric}
        ColNames(1,:) string 
        TitleText(1,:) string
    end
    
    methods (Access = protected)
        function setup(obj)
            % Use one toolbar for all of the axes
            axtoolbar(getLayout(obj),'default');
        end
        
        function update(obj)
            % Get the layout and store it as tcl
            tcl = getLayout(obj);
            numvars = size(obj.Data,2);
             
            % Reconfigure layout if needed
            if numvars ~= tcl.GridSize(1)
                % Delete layout contents to change the grid size
                delete(tcl.Children);
                if numvars>0
                    tcl.GridSize = [numvars numvars];
                    for i = 1:numvars^2
                        nexttile(tcl,i);
                    end
                end
            end
            
            % Populate the layout with the axes
            ax = gobjects(numvars,numvars);
            for col = 1:numvars
                for row = 1:numvars
                    % Get the axes at the current row/column
                    t = col + (row-1) * numvars;
                    ax(row,col)=nexttile(tcl,t);
                    if col==row
                        % On the diagonal, draw histograms
                        histogram(ax(row,col),obj.Data(:,col));
                        ylabel(ax(row,col),'Count')
                    else
                        % Off the diagonal, draw scatters
                        scatter(ax(row,col),obj.Data(:,col),...
                            obj.Data(:,row),'filled','MarkerFaceAlpha',0.6)
                        if length(obj.ColNames) >= row
                            ylabel(ax(row,col),obj.ColNames(row));
                        end
                    end
                    
                    if length(obj.ColNames) >= col
                        xlabel(ax(row,col),obj.ColNames(col));
                    end
                end
                
                % Link the x-axis for each column, so that panning or zooming
                % affects all axes in the column.
                linkaxes(ax(:,col),'x')
            end
            
            % Chart title
            title(tcl,obj.TitleText,'FontSize',16);
        end
    end
end

После того, чтобы сохранить файл класса создайте экземпляр графика.

load patients
chartTitle = "Height, Weight, and Diastolic Blood Pressure";
c = TrellisChart('Data',[Height Weight Diastolic], ...
    'colNames', ["Height" "Weight" "Diastolic"],...
    'TitleText',chartTitle);

Смотрите также

Функции

Классы

Свойства

Похожие темы