WICHTIG: Der Betrieb von goMatlab.de wird privat finanziert fortgesetzt. - Mehr Infos...

Mein MATLAB Forum - goMatlab.de

Mein MATLAB Forum

 
Gast > Registrieren       Autologin?   

Partner:




Forum
      Option
[Erweitert]
  • Diese Seite per Mail weiterempfehlen
     


Gehe zu:  
Neues Thema eröffnen Neue Antwort erstellen

Problem mit axes nextplot

 

DSP
Forum-Meister

Forum-Meister



Beiträge: 2.117
Anmeldedatum: 28.02.11
Wohnort: ---
Version: R2014b
     Beitrag Verfasst am: 21.02.2016, 23:57     Titel: Problem mit axes nextplot
  Antworten mit Zitat      
Hallo goMatlab Forum,

ich habe ein Problem beim Ploten. Beim Start der GUI wird das axes Objekt mit der CreateFcn initalisiert. Dann drückt man den Button um ein Zufallssignal darzustellen. Die Textbox muss somit verschwinden.

Ist die Axes Eigenschaft nextplot auf...

Code:

handles.axh = axes(...
'NextPlot','replace',...
 


gesetzt, fehlt jegliche graphische Formatierung von axes wenn ein neuer Plot erstellt wird. Setze ich die Eigenschaft auf 'add', stimmt die Darstellung der CreateFcn. Für einen neuen Plot muss ich nun aber in der Button Callback die Textbox löschen, da der nächste Plot einfach darüber gestellt wird.

Mit
Code:
cla(handles.axh,'reset')


fehlt dann wieder die graphische Formatierung. Mit cla werden zwar Graphikobjekte gelöscht, aber das xLabel bleibt gleich, da es schon in der CreateFcn gesetzt wird. Das xlim wird dann einfach ignoriert.

Muss ich denn tatsächlich alle axes Eigenschaften nach dem reset wieder alle setzen, oder gibt es eine andere Möglichkeit um einen neuen Plot zu erstellen? Hier ein Beispiel...

Code:

function [] = nextplotTest()
%% ---- SignalViewer GUI mainfile ---------------------------------------

% GUI Color Codes
handles.Data.Color.BackgroundGrey = [38/255 38/255 38/255];
handles.Data.Color.ButtonGrey = [102/255 102/255 102/255];
handles.Data.Color.ButtonRed = [255/255 69/255 0/255];
handles.Data.Color.ButtonGreen = [50/255 205/255 50/255];
handles.Data.Color.FontColor = [1 1 1];

handles.Data.Color.AxesBackground = [221/255 221/255 221/255];
handles.Data.Color.TextBackground = [161/255 161/255 161/255];
handles.Data.Color.Grid = [0 0 0];


handles.MainWindow = figure(...
'PaperUnits','inches',...
'Units','normalized',...
'Position',[0 0 0.8 0.9],...
'Visible','off',...
'CurrentAxesMode','manual',...
'IntegerHandle','off',...
'MenuBar','none',...
'ToolBar','none',...
'Name','test',...
'NumberTitle','off',...
'Resize','on',...
'ScreenPixelsPerInchMode','manual',...
'ChildrenMode','manual',...
'ParentMode','manual',...
'HandleVisibility','on',...
'Tag','SignalViewer',...
'Color',handles.Data.Color.BackgroundGrey,...
'CreateFcn', {@movegui,'center'});

handles.axh = axes(...
'Parent',handles.MainWindow,...
'FontUnits',get(0,'defaultaxesFontUnits'),...
'Units','normalized',...
'XColor',handles.Data.Color.FontColor,...
'YColor',handles.Data.Color.FontColor,...
'ZColor',handles.Data.Color.FontColor,...
'Color',handles.Data.Color.AxesBackground,...
'Position',[0.08 0.08 0.84 0.84],...
'XGrid','on',...
'YGrid','on',...
'ZGrid','on',...
'GridLineStyle','--',...
'GridColor',handles.Data.Color.Grid,...
'GridAlpha',0.15,...
'MinorGridLineStyle','--',...
'XMinorGrid','off',...
'YMinorGrid','off',...
'ZMinorGrid','off',...
'MinorGridColor',handles.Data.Color.Grid,...
'MinorGridAlpha',0.07,...
'Tag','axh',...
'ParentMode','manual',...
'NextPlot','add',...
'CreateFcn', {@PlotInit_CreateFcn});

handles.button = uicontrol(...
'Parent',handles.MainWindow,...
'FontUnits',get(0,'defaultuicontrolFontUnits'),...
'Units','normalized',...
'String','Press',...
'Style','pushbutton',...
'Position',[0.1 0.946 0.1 0.03],...
'Callback',{@NewPlot_Callback},...
'Children',[],...
'ParentMode','manual',...
'Tag','button');

% GUI created, show now
set(handles.MainWindow,'Visible','on')

Ts = 1;

% UIWAIT makes GUI wait for user response (see UIRESUME)
uiwait(handles.MainWindow)

% create new data and plot them
    function NewPlot_Callback(varargin)
             
        axh = handles.axh;
        cla % clear plot  
%         cla(axh,'reset')
%         axh = newplot(handles.axh);
        Ts = Ts*0.1;
        N = 1024;
        t = 0:Ts:(N-1)*Ts;
        y = randn(1,N);
        plot(axh,t,y)
        axis tight
        xlim(axh,[0 t(end)])
    end


% initial Plot on Signalviewer startup - show some Informations
    function PlotInit_CreateFcn(hObject, ~)
        % create empty plot        
        plot(hObject,1:10, NaN(10))
        set(hObject,'XLim', [1 10])
        set(hObject,'XTickLabel',{'1';'2';'3';'4';'5';'6';'7';'8';'9';'10'})  
       
        % show information
        info = sprintf('Information:\n\n');
       
        handles.Data.hInfoText = text(2,0.8,info,...
                                    'FontSize',12,...
                                    'FontWeight','bold',...
                                    'Color',handles.Data.Color.FontColor,...
                                    'BackgroundColor',handles.Data.Color.BackgroundGrey);        

    end
end
 


Vielen Dank für eure Hilfe!

Gruß DSP
Private Nachricht senden Benutzer-Profile anzeigen


DSP
Themenstarter

Forum-Meister

Forum-Meister



Beiträge: 2.117
Anmeldedatum: 28.02.11
Wohnort: ---
Version: R2014b
     Beitrag Verfasst am: 22.02.2016, 15:28     Titel:
  Antworten mit Zitat      
Hallo,

auch wenn niemand eine Lösung kennt, kann mir evtl jemand eklären wieso bei nextplot = replace keine graphische Formatierung zu sehen ist? Nicht mal ticklabels, obwohl in axh in der Button Callback welche definiert sind und ich das cla auskommentiere. Das ist doch irgendwie merkwürdig zumal nextplot = replace der Default ist.

Gruß DSP
Private Nachricht senden Benutzer-Profile anzeigen
 
Winkow
Moderator

Moderator



Beiträge: 3.842
Anmeldedatum: 04.11.11
Wohnort: Dresden
Version: R2014a 2015a
     Beitrag Verfasst am: 22.02.2016, 16:46     Titel:
  Antworten mit Zitat      
hey dsp. da hier sonst keiner was schreibt hab ich mich mal doch durchgerungen zu antworten Smile ich seh noch nicht so ganz durch da ich da grade nicht in der materie stehe und es mir schwer fällt mich da anhand deiner informationen so fix reinzuarbeiten. kannst du nochmal für anfänger erklären welche werte du jetzt gerne wo erhalten haben willst? also was genau nicht klappt? damit ich das mal besser nachvolziehen kann. vielleicht fällt mir dann ja spontan was ein Smile
grüße
_________________

richtig Fragen
Private Nachricht senden Benutzer-Profile anzeigen
 
DSP
Themenstarter

Forum-Meister

Forum-Meister



Beiträge: 2.117
Anmeldedatum: 28.02.11
Wohnort: ---
Version: R2014b
     Beitrag Verfasst am: 22.02.2016, 17:05     Titel:
  Antworten mit Zitat      
Das axes Objekt ist mit Eigenschaften wie Farben etc. vordefiniert. Siehe

Code:
handles.axh = axes(...


Nun startet man die GUI (der Code ist lauffähig) und der Plot soll initialisert werden, wofür ich die axes CreateFcn nutze. Hier fangen aber meine Probleme schon. Nur wenn die axes Eigenschaft nextplot = add gesetzt wird, sind auch meine gewünschten Farben,Schriftgrößen etc zu sehen. Bei nextplot = replace fehlt das alles.

Setze ich nextplot = add habe ich aber dann das Problem, wenn ich etwas Neues plotten möchte. Dafür ist der Button in der testgui. Durch add wird einfach über das bereits im Plot existierende "gemalt". Das will ich natrülich nicht.

Der Befehl cla löscht dann zwar die graphischen Objekte, nicht aber z.B. Ticklabels. Somit werden sie auch nicht bei neuen Daten im Plot aktualisiert. Die Grenzen des xlim Befehl in der Button Callback werden nicht gesetzt.

Code:
cla(axh,'reset')


löscht alles bis auf Positionen. Damit ist dann wieder meine graphische Formatierung weg. Es muss doch eine Weg geben, ohne jedesmal bei einem neuen Plot im gleichen axes handle, die axes settings erst wieder zuweisen zu müssen.

Aber grundlegend verstehe ich schon nicht warum es nicht mit nextplot = replace(children) funktioniert. Warum sind dann alle axes settings "weg"?
Private Nachricht senden Benutzer-Profile anzeigen
 
DSP
Themenstarter

Forum-Meister

Forum-Meister



Beiträge: 2.117
Anmeldedatum: 28.02.11
Wohnort: ---
Version: R2014b
     Beitrag Verfasst am: 22.02.2016, 17:37     Titel:
  Antworten mit Zitat      
Die letzte Frage kann ich mir selbst beantworten:

Zitat:
'replace' — Reset all axes properties, except Position and Units, to their default values and delete all axes children before displaying the new plot. Using this value is similar to using cla reset.


Obwohl ich die Doku zu axes properties gelesen habe, ist mir das entgangen Embarassed . Damit fällt dieses setting schon mal aus.

Sieh wie es ausschaut muss ich 'replacechildren' verwenden. Nur sind dann die xticks immer auf die Werte aus der CreateFcn gesetzt. Rolling Eyes
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.495
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 22.02.2016, 18:21     Titel:
  Antworten mit Zitat      
Hallo,

könnte es das Problem lösen, statt eines neuen Plots die Daten zu überschreiben?

Ansonsten stellt sich mir die Frage: soll der Text immer an der selben Stelle bleiben?

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
DSP
Themenstarter

Forum-Meister

Forum-Meister



Beiträge: 2.117
Anmeldedatum: 28.02.11
Wohnort: ---
Version: R2014b
     Beitrag Verfasst am: 22.02.2016, 19:50     Titel:
  Antworten mit Zitat      
Hallo Harald,

ehrlich gesagt verstehe ich deine Fragen nicht. Der Infotext in der CreateFcn ist natürlich in der eigentlich GUIversion deutlich umfangreichen. Er soll nur beim Start der GUI gezeigt werden, weshalb ich ihn in die CreateFcn gepackt habe. Sobald der User dann Signale darstellt, sollen diese Infos nicht mehr gezeigt werden.

Ich verzichte jetzt einfach auf das manuelle setzen von ticklabels in der CreateFcn. Dann habe ich auch kein Problem in den neuen Plots, da sie dann mit nextplot = replacechildren aktualsisiert werden können. Das scheint bei einem kurzen Test erstmal zu funktionieren.

Möglichweise würde es auch Abhilfe schaffen statt der CreateFcn eine normale Funktion zu erstellen, die dann aufgerufen wird, wenn alle GUI Objekte erzeugt sind.

Gruß DSP
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.495
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 22.02.2016, 20:27     Titel:
  Antworten mit Zitat      
Hallo,

Zitat:
Er soll nur beim Start der GUI gezeigt werden, weshalb ich ihn in die CreateFcn gepackt habe. Sobald der User dann Signale darstellt, sollen diese Infos nicht mehr gezeigt werden.

Genau das passiert doch momentan? Dann verstehe ich noch nicht, was dich am momentanen Verhalten stört.

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
DSP
Themenstarter

Forum-Meister

Forum-Meister



Beiträge: 2.117
Anmeldedatum: 28.02.11
Wohnort: ---
Version: R2014b
     Beitrag Verfasst am: 22.02.2016, 20:49     Titel:
  Antworten mit Zitat      
Dann schau mal in dem oberen Bsp auf die xticklabels nachdem der Button gedrückt wird. Sie sollten nicht von 1...10 gehen und dannach weiter mit 1 Wink

In der CreateFcn wurden sie gesetzt und können somit nicht mehr automatisch verändert werden. Ich müsste sie also jedesmal bei einem neuen plot manuell setzen, oder cla reset nutzen und müsste dann die axes settings neu zuweisen. Diese beiden Optionen will ich aber vermeiden.

Es geht hier nicht um die CreateFcn sondern um die folgenden Plots. Hier hatte ich bisher das Problem, dass entweder alles übereinander geplottet wird (nextplot = add). Oder die axes settings verloren gehen (nextplot = replace). Oder aber die ticklabels nicht mehr automatisch geändert werden (nextplot = replacechildren/add).
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.495
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 22.02.2016, 21:11     Titel:
  Antworten mit Zitat      
Hallo,

ich würde XTickLabel und XTick immer zusammen setzen.
Code:
set(hObject,'XTick', 1:10)


So bleibt die Beschriftung in den folgenden Schritten an den gleichen Stellen.
Soll das so passieren und wenn nicht: was stattdessen?

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
DSP
Themenstarter

Forum-Meister

Forum-Meister



Beiträge: 2.117
Anmeldedatum: 28.02.11
Wohnort: ---
Version: R2014b
     Beitrag Verfasst am: 22.02.2016, 21:58     Titel:
  Antworten mit Zitat      
Daran hängt es nicht. Hast du dir mal angesehen was dann mit den Labels bei nachfolgenden Plots durch Drücken des Buttons passiert? Da kommt doch nur Mist raus.

Ich möchte...neuer Plot = neue tickLabels, welche automatisch neu gesetzt werden entsprechen den Vorgaben aus x/ylim. Das geht nur mit nextplot = replace. Was davon der Nachteil ist, habe ich schon mehrfach erwähnt.

Offensichtlich darf ich die ticklabels in der CreateFcn nicht setzen. Sonst werde ich sie automatisch nicht wieder los. Ich dachte daher es gibt evtl. eine Kombination aus nextplot, cla, newplot oder ähnliches, welche mir die Graphikobjekte löscht und dann beim erneuten Plotbefehlt aber die Settings (Color, Grid etc.) von axes behält, aber die ticklabels neu richtig setzt.
Private Nachricht senden Benutzer-Profile anzeigen
 
Jan S
Moderator

Moderator


Beiträge: 11.057
Anmeldedatum: 08.07.10
Wohnort: Heidelberg
Version: 2009a, 2016b
     Beitrag Verfasst am: 23.02.2016, 00:22     Titel:
  Antworten mit Zitat      
Hallo DSP

Zitat:
In der CreateFcn wurden sie gesetzt und können somit nicht mehr automatisch verändert werden. Ich müsste sie also jedesmal bei einem neuen plot manuell setzen, oder cla reset nutzen und müsste dann die axes settings neu zuweisen. Diese beiden Optionen will ich aber vermeiden.


Ich verstehe das Problem immer noch nicht.
Wenn die XTickLabels gesetzt werden, wird die Automatik ausgeschaltet. Das sieht man z.B. am Wert von XTickLabelMode, der dann auf 'manual' gesetzt wird. Das ist ja das gewollte Verhalten, wenn man die XTickLables manuell setzt.
Wenn sich nun die XTicks ändern, bleiben die XTickLabels immer noch wie vorher gesetzt, denn die Automatik ist ja explizit ausgeschaltet worden. Dass dann 1 bis 10 erscheint und es dann wieder mit 1 anfängt usw. ist also logisch.

Entweder man setzt die XTicks und XTickLabels (wie HArald schon erwähnte) immer gleichzeitig, oder man schaltet die Automatiken für beide wieder ein:
Code:
cla;
set(gca, 'XTickMode', 'auto', 'XTickLabelMode', 'auto')

Dass das nicht in cla intergriert ist, ist eine Geschmacksfrage, genauso wie ob es bei 'NextPlot'='replace' durchgeführt werden soll oder nicht.

Löst das Setzen der Modes Dein Problem? Wenn nicht, habe ich es wohl wirklich nicht verstanden.

Gruß, Jan
Private Nachricht senden Benutzer-Profile anzeigen
 
DSP
Themenstarter

Forum-Meister

Forum-Meister



Beiträge: 2.117
Anmeldedatum: 28.02.11
Wohnort: ---
Version: R2014b
     Beitrag Verfasst am: 23.02.2016, 09:26     Titel:
  Antworten mit Zitat      
Hallo Jan,

danke für den Hinweis bzgl. des TickLabelModes und cla. Für die TickLabels ist damit meine Frage beantwortet. Das man XTicks und XTickLabels immer zusammensetzen sollte, ist ir bewusst. Harald weist nicht das erste mal darauf hin. Allerdings ist es in diesem Fall nicht die Ursache für die falschen ticklabels bei nachfolgenden Plots. Eine Frage habe ich allerdings noch.

Wo ist der Unterschied zwischen

axes property nextplot = replacechildren

und

cla(axh)?

Gruß DSP
Private Nachricht senden Benutzer-Profile anzeigen
 
Jan S
Moderator

Moderator


Beiträge: 11.057
Anmeldedatum: 08.07.10
Wohnort: Heidelberg
Version: 2009a, 2016b
     Beitrag Verfasst am: 23.02.2016, 10:27     Titel:
  Antworten mit Zitat      
Hallo DSP,

Ich würde es einfach mal ausprobieren.
Code:
H1 = axes('NextPlot', 'replacechildren');
plot(1:10);
plot(2:11);
Prop1 = get(H1);

H2 = axes('NextPlot', 'replace');
plot(1:10);
cla(H2);
plot(2:11);
Prop2 = get(H2);

Nun braucht man ein Tool um Structs feldweise zu vergleichen. Ich habe dafür ein "ComparStruct" geschrieben, das aber nicht veröffentlichungsreif ist. Die Ergebnisse kann ich auch gerade nicht ermitteln, da ich hier kein Matlab zur Verfügung habe.

Zudem bleibt zu befürchten, dass undokumentierte Unterschiede von der Matlab-Version abhängen könnten. Wenn es in einem Code wirklich auf das Verhalten ankommt, würde ich es deshalb explizit schreiben und mich nicht auf die 'NextPlot' und CLA-Schlauheiten verlassen. Ich verwende aber auch grundsätzlich kein gca und gcf , füge in plot Befehlen immer die 'Parent' Eigenschaft ein und schreibe immer sum(x, 1) statt mich darauf zu verlassen, dass sum(x) schon tut, was ich mir wünsche.

Gruß, Jan
Private Nachricht senden Benutzer-Profile anzeigen
 
DSP
Themenstarter

Forum-Meister

Forum-Meister



Beiträge: 2.117
Anmeldedatum: 28.02.11
Wohnort: ---
Version: R2014b
     Beitrag Verfasst am: 23.02.2016, 10:44     Titel:
  Antworten mit Zitat      
Hallo Jan,

hier müsste es doch aber heißen:

Code:
H2 = axes('NextPlot', 'add');


Denn replacechildren löscht alle axes child Objekte, aber alle anderen axes properties bleiben erhalten. Axes nextplot = replace setzt alles bis auf Position und Einheiten zurück. cla(axh) löscht ebenfalls alle axes child Objekte, deren handle visibility = on ist. Daher der Vergleich von cla und replacechildren. In der Doku zu nextplot wird angegeben...

Zitat:
'replacechildren' — Remove all child objects before adding new plots, but do not reset axes properties. This is similar to using cla.


Bedeutet das nun gleich oder ähnlich? Wenn Letzteres...wo ist dann der Unterschied? Nur in der Löschbedingung handle visibility = on für Objekte? Ich konnte in der Doku dazu leider keine genaueren Infos finden.

Letztendlich habe ich diesen Thread ja gestartet, um eine Lösung für das Bestehen der axes settings und das Löschen von Graphikobjekten bei wiederholenden plot Befelen zu bekommen.
Private Nachricht senden Benutzer-Profile anzeigen
 
Neues Thema eröffnen Neue Antwort erstellen

Gehe zu Seite 1, 2  Weiter

Einstellungen und Berechtigungen
Beiträge der letzten Zeit anzeigen:

Du kannst Beiträge in dieses Forum schreiben.
Du kannst auf Beiträge in diesem Forum antworten.
Du kannst deine Beiträge in diesem Forum nicht bearbeiten.
Du kannst deine Beiträge in diesem Forum nicht löschen.
Du kannst an Umfragen in diesem Forum nicht mitmachen.
Du kannst Dateien in diesem Forum posten
Du kannst Dateien in diesem Forum herunterladen
.





 Impressum  | Nutzungsbedingungen  | Datenschutz | FAQ | goMatlab RSS Button RSS

Hosted by:


Copyright © 2007 - 2025 goMatlab.de | Dies ist keine offizielle Website der Firma The Mathworks

MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.