В этом примере показано, как задать класс для создания плиточного размещения графиков, которая может быть любого размера, в зависимости от размера данных пользователя. График имеет общедоступное Data
свойство, которое принимает матрицу m на n. На графике отображается квадратное плиточное размещение n на n из графиков поля точек и гистограмм. На графиках поля точек показаны различные столбцы данных, нанесенных друг на друга. Гистограммы показывают распределение значений в каждом столбце данных.
The 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);