Graphik wird nicht vollständig gezeichnet. Bitte um Tipp!
Ben20
Forum-Newbie
Beiträge: 7
Anmeldedatum: 14.05.10
Wohnort: Stuttgart
Version: ---
Verfasst am : 25.05.2010, 13:54
Titel : Graphik wird nicht vollständig gezeichnet. Bitte um Tipp!
Hallo Freunde,
ich muss das Fliegen eines Flugzeugs im 3D-Raum zeichnen. Aber leider hat das Programm nicht alles gezeichnet die Flügel (Linie f1-f6) sind da, aber leider fehlt noch der komplette Rumpf mit der Seitenflosse, da wurde nur ein Strich gezeichnet. Das Flugzeugmodell ist nicht räumlich sondern einfach nur zwei zueinander senkrechte Ebenen.
Was kann ich hier noch ändern, um den Rumpf senkrecht zum Flügel zeichnen zu können?
Das aktuell gezeichnete könnt ihr unter dem folgenden Link ansehen:
http://www.bilder-hochladen.net/files/bdgr-2.jpg
Würde mich sehr über eine Antwort freuen und bedanke mich schon im Voraus.
Gruß Ben
Code:
function [ sys,xa,str,ts] = Life_Graphik_Flying( t,x,u,flag)
persistent p_1;
global f1 f2 f3 f4 f5 f6 f7 f8 f9 f10 f11 f12 f13;
EraseM = 'normal ';
switch flag,
case 0 % Init Block
sys = [ ] ;
sizes = simsizes;
sizes.NumContStates = 0 ;
sizes.NumDiscStates = 0 ;
sizes.NumInputs = 3 ; % Anzahl u
sizes.NumOutputs = 0 ;
sizes.DirFeedthrough = 0 ;
sizes.NumSampleTimes = 1 ;
sys = simsizes( sizes) ;
str = [ ] ;
xa = [ ] ;
ts = [ -1 0 ] ;
lh = [ f1 f2 f3 f4 f5 f6 f7 f8 f9 f10 f11 f12 f13] ;
delete ( lh ( ishandle ( lh ) ) ) ;
%% User
figure ( 1 ) ; clf ;
cameratoolbar ( 'show ') ;
set ( gcf ,'color ', [ 1 1 1 ] *.8 , ...
'name ', 'I believe I can fly ',...
'numbertitle ','off ') ;
p_1 = line ( 'marker ','o ','markerfacecolor ','r ','markersize ',5 ,...
'erasemode ','none ','Xdata ',[ ] ,'Ydata ', [ ] , 'Zdata ', [ ] ) ;
axis equal;
axis ( [ -500 5000 -500 5000 -1000 5000 ] ) ;
grid off;
set ( gca ,'color ', [ 1 1 1 ] *.8 ) ;
f1 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
f2 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
f3 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
f4 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
f5 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
f6 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
f7 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
f8 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
f9 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
f10 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
f11 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
f12 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
f13 = line ( 'xData ',[ NaN NaN ] ,'yData ',[ NaN NaN ] , 'zData ',[ NaN NaN ] , 'Color ','k ','lineWidth ',2 ,'EraseMode ',EraseM) ;
case 2 %Aktualisierung
sys =[ ] ;
figure ( 1 ) ;
hold on;
x1 = 150 ; y1 = 0 ; z1=0 ; x2 = -250 ; y2 = 450 ; z2=0 ;
set ( f1,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
x1 = -250 ; y1 = 450 ; z1=0 ; x2 = -400 ; y2 = 450 ; z2=0 ;
set ( f2,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
x1 = -400 ; y1 = 450 ; z1=0 ; x2 = -150 ; y2 = 0 ; z2=0 ;
set ( f3,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
x1 = -150 ; y1 = 0 ; z1=0 ; x2 = -400 ; y2 = -450 ; z2=0 ;
set ( f4,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
x1 = -400 ; y1 = -450 ; z1=0 ; x2 = -250 ; y2 = -450 ; z2=0 ;
set ( f5,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
x1 = -250 ; y1 = -450 ; z1=0 ; x2 = 150 ; y2 = 0 ; z2=0 ;
set ( f6,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
x1 = -550 ; y1=0 ; z1 = -50 ; x2 = -600 ; y2=0 ; z2 = 350 ;
set ( f7,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
x1 = -600 ; y1=0 ; z1 = 350 ; x2 = -500 ; y2=0 ; z2 = 350 ;
set ( f8,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
x1 = -500 ; y1=0 ; z1 = 350 ; x2 = -400 ; y2=0 ; z2 = 150 ;
set ( f9,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
x1 = -400 ; y1=0 ; z1 = 150 ; x2 = 400 ; y2=0 ; z2 = 150 ;
set ( f10,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
x1 = 400 ; y1=0 ; z1 = 150 ; x2 = 600 ; y2=0 ; z2 = 50 ;
set ( f11,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
x1 = 600 ; y1=0 ; z1 = 50 ; x2 = 550 ; y2=0 ; z2 = 50 ;
set ( f12,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
x1 = 550 ; y1=0 ; z1 = 50 ; x2 = -550 ; y2=0 ; z2 = 50 ;
set ( f13,'xData ',[ u( 1 ) +x1-y1-z1 u( 1 ) +x2-y2-z2] ,...
'yData ',[ u( 2 ) +x1+y1-z1 u( 2 ) +x2+y2-z2] ,...
'zData ',[ u( 3 ) +x1+y1-z1 u( 3 ) +x2+y2-z2] ) ;
set ( p_1, 'Xdata ', u( 1 ) , 'Ydata ', u( 2 ) ,'Zdata ', u( 3 ) ) ;
drawnow ;
case -1 % clear
clear global f1 f2 f3 f4 f5 f6 f7 f8 f9 f10 f11 f12 f13;
end ;
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
Impressum
| Nutzungsbedingungen
| Datenschutz
| FAQ
| 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.