Verfasst am: 17.12.2007, 14:05
Titel: Problem mit Slidern
Hallihallo,
ich habe ein Problem mit Slidern.
Ich habe drei UI-Objekte:
-ein Textedit (fitparameter)
-einen Slider (um den Fitpar. zu vergrößern oder zu verkleinern)
-ein Textedit (mit der Schrittweite für den Slider)
So, nun zu meiner Frage/Code. In der Callback-Methode des sliders steht in etwa (also auszugsweise)
Code:
function SL_Rp_fit_Callback(hObject, eventdata, handles)
stepSize = str2num(get(handles.TE_stepsize_R_p,'String'))
value = str2num(get(handles.TE_Rp_fit, 'String'))
oldSliderPos = get(hObject, 'Value') %Woher den alten Wert bekommen???
newsliderPos = get(hObject, 'Value')
if oldSliderPos<newSliderPos
newValue = value+stepSize
else
newValue = value-stepSize
end
Ich möchte, wie man dem Code (hoffentlich) entnehmen kann in der Callbackfunktion des Sliders also die Ausgabe im Textedit des Fitparameters regeln. Dazu müsste ich den "alten" und den "neuen" Slider-Positions-Parameter miteinander vergleichen, und demensprechend dann per if-Abfrage den richtigen neuen Wert setzen. Das Problem ist, sobald ich natürlich den slider bewege und somit die Callback-funktion auslöse, der "alte" Wert schon überschrieben wurde... kann man das irgendwie geschickter lösen?
Danke schonmal im Vorraus für anregungen und Tipps
P.S.: Dass bei oldSliderPosition und newSliderPosition natürlich nicht das gleiche stehen kann/darf, ist mir auch klar, hab das nur hier im Code mal so geschrieben, damit es vlt etwas klarer wird, was ich meine
_________________
*Oink oink, kommt her, ihr Schweinchen! Oink oink!*
solange Du nicht selbst darum kümmerst, kriegst Du den auch nirgends, aber
Wenn du in jedem Aufruf des Callbacks den aktuellen Wert ausliest und abspeicherst,
dann steht diese beim nächsten Aufruf dir als OLD-Wert zur Verfügung...
Nur für den allerersten Aufruf muss Du einen den Old-Wert mit etwas initialisieren.
Code:
function SL_Rp_fit_Callback(hObject, eventdata, handles)
stepSize = str2num(get(handles.TE_stepsize_R_p,'String'))
value = str2num(get(handles.TE_Rp_fit, 'String'))
try % den im letzten Aufruf gespeicherten Wert auslesen
oldSliderPos = get(hObject, 'UserData',newsliderPos) catch % für den allerersten Aufruf, wenn noch nichts im UserData abgelegt % wurde, wird der Wert auf 0 gesetzt
oldSliderPos = 0;
end
%
% man kann den TRY-Block sich sparen, % wenn man den Initialwert per GUIDE im UserData des Sliders manuel einträgt
%
% aktuellen Wert auslesen
newsliderPos = get(hObject, 'Value')
%
% den aktuellen Wert für den folge-Aufruf speichern set(hObject, 'UserData',newsliderPos)
if oldSliderPos<newSliderPos
newValue = value+stepSize
else
newValue = value-stepSize
end
Vielen Dank erstmal an Outsider. Hat bei mir nicht ganz so getan mit dem try und catch, allerdings kannte ich das mit dem 'UserData' noch nicht, hab aber davon in meiner Variante nun ausgiebig davon Gebrauch gemacht und eine andere Lösung gefunden:
Code:
function SL_Rp_fit_Callback(hObject, eventdata, handles) clc
stepSize = str2num(get(handles.TE_stepsize_R_p,'String'));
value = str2num(get(handles.TE_Rp_fit, 'String'));
ifisempty(get(hObject,'UserData')) %Schaue nach, ob oldSliderPos schon nen Wert hat. Wenn nicht
oldSliderPos = get(hObject,'Min') %setze es auf den minimalen Sliderwert
else %Wenn es jedoch ein nicht-leeres Objekt ist,
oldSliderPos = get(hObject, 'UserData') %setze den Wert auf den alten Sliderwert
end
newSliderPos = get(hObject, 'Value'); %Den neuen Wert des Sliders holen
set(hObject, 'UserData',newSliderPos) %und ihn in der Variablen UserData zwischenspeichern
if oldSliderPos<newSliderPos %Nun den Vergleich starten zwischen alter und neuer Sliderposition
newValue = value+stepSize %und im jeweiligen Fall den neuen Fitwert reinrechnen
else
newValue = value-stepSize
end
set(handles.TE_Rp_fit, 'String',num2str(newValue)); %Dann den richtigen Fitwert noch in das Textedit schreiben
guidata(hObject, handles);
*Oink oink, kommt her, ihr Schweinchen! Oink oink!*
Einstellungen und Berechtigungen
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
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.