Contenu principal

Flight Instrument Components in App Designer

Create aerospace-specific applications in App Designer using common aircraft flight instruments. App Designer is a rich development environment that provides layout and code views, a fully integrated version of the MATLAB® editor, and a large set of interactive components. For more information on App Designer, see Develop Apps Using App Designer. To use the flight instrument components in App Designer, you must have an Aerospace Toolbox license.

For a simple flight instruments app example that uses the App Designer, see the Getting Started examples when you first start App Designer. To create an app to visualize saved flight data for a Piper PA-24 Comanche, use this workflow.

  1. Start App Designer by typing appdesigner at the command line, and then select Blank App on the Getting Started page.

  2. Drag aerospace components from the Component Library to the app canvas.

  3. To load simulation data, add a startup function to the app, and then create an animation object.

  4. Enter the callbacks, functions, and properties for the components to the app. Also add associated code.

  5. Trigger a display of the animation in the instrument app.

  6. Save and run the app.

The following topics contain more detailed steps for this workflow as an example. This example uses an Aero.Animation object.

Start App Designer and Create a New App

  1. Start App Designer. In the MATLAB Command Window, type:

    appdesigner
  2. In the App Designer welcome window, click Blank App. App Designer displays with a blank canvas.

  3. To look at the blank app template, click Code View. Notice that the app contains a template with sections for app component properties, component initialization, and app creation and deletion.

  4. To return to the canvas view, click Design View.

Drag Aerospace Components into the App

To drag components to the blank canvas:

  1. In the Component Library, navigate to Aerospace.

  2. From the library, drag these aerospace components to the canvas:

    • Airspeed Indicator

    • Artificial Horizon

    • Turn Coordinator

    • Heading Indicator

    • Climb Indicator

    • Altimeter

  3. This example uses an Aero.Animation object to visualize the flight status of an aircraft over time. To set the current time, add a time input device such as a slider or knob. As you change the time on the time input device, the flight instrument components and the animation window update to show the results. The example code provides further details.

    For this example:

    • Add a Slider component as a time input device.

    • To display the current time from the slider, edit the label of the slider. For example:

      • Change the label to Time: 00.0 sec.

      • Change the upper limit to 50.

  4. Click Code View and note that the properties and component initialization sections now contain definitions for the new components. The code managed by App Designer is noneditable (grayed out).

  5. In the Property Inspector pane on the right of the canvas, double-click and rename these components:

    • UIfigure component to FlightInstrumentsFlightDataPlaybackUIFigure

    • Slider component to Time000secSlider

Add Code to Load and Visualize Data for the App

  1. In the code view for the app, place the cursor after the properties section and, in the Insert section, click Callback.

    The Add Callback Function dialog box displays.

  2. In the Add Callback Function dialog box:

    1. From the Callback list, select StartupFcn.

    2. In the Name parameter, enter a name for the startup function, for example startupFcn.

      A callbacks section is added.

  3. Add additional properties to the class for the simulation data and the animation object. Place your cursor just after the component properties section and, in the Insert section, click Property > Public Property. In the new properties template, copy code so that it looks like this:

    simdata % Saved flight data [time X Y Z phi theta psi]
    animObj % Aero.Animation object

    simdata is the saved flight data. animObj is the Aero.Animation object for the figure window.

  4. To the startupFcn section, below the previously added section, add code to the startup function that loads simulation data. The simdata.mat file contains logged simulated flight trajectory data.

    % Code that executes after component creation
    function startupFcn(app)
                
           % Load saved flight status data
           savedData = load("simdata.mat");
           yaw = savedData.simdata(:,7);
           yaw(yaw<0) = yaw(yaw<0)+2*pi; % Unwrap yaw angles
           savedData.simdata(:,7) = yaw;
           app.simdata = savedData.simdata;  % Load saved flight status data

  5. To visualize animation data, create an animation object. After loading the simulation data:

    1. Create an Aero.Animation object.

      app.animObj = Aero.Animation;
    2. Use the piper pa-24 comanche geometry for the animation object.

      app.animObj.createBody('pa24-250_orange.ac','Ac3d'); % Piper PA-24 Comanche geometry
    3. Use the data loaded previously, app.simdata, as the source for the animation object.

      app.animObj.Bodies{1}.TimeSeriesSourceType = 'Array6DoF'; % [time X Y Z phi theta psi]
      app.animObj.Bodies{1}.TimeSeriesSource = app.simdata;
    4. Initialize the camera and figure positions.

      app.animObj.Camera.PositionFcn = @staticCameraPosition;
      app.animObj.Figure.Position = [app.FlightInstrumentsFlightDataPlaybackUIFigure.Position(1)+625,...
          app.FlightInstrumentsFlightDataPlaybackUIFigure.Position(2),...
          app.FlightInstrumentsFlightDataPlaybackUIFigure.Position(3),...
          app.FlightInstrumentsFlightDataPlaybackUIFigure.Position(4)];
      app.animObj.updateBodies(app.simdata(1,1)); % Initialize animation window at t=0
      app.animObj.updateCamera(app.simdata(1,1));
    5. Create and show the figure graphics object.

      app.animObj.show();

Add Code to Trigger a Display of the Animation Object

To trigger an update of the animation object and flight instruments:

  1. In the code view for the app, add a callback for the slider. Navigate to the Property Inspector section and select app.Time000secSlider.

  2. Click on the Callbacks tab and enter a name for ValueChangingFcn, Time000secSliderValueChanging, and press Enter.

    In the code view, App Designer adds a callback function Time000secSliderValueChanging.

  3. Add code to display the current time in the slider label Time000secSliderLabel:

    % Display current time in slider component
    t = event.Value;
    app.Time000secSliderLabel.Text = sprintf('Time: %.1f sec', t);
  4. Under the previously added code, add code to compute data values for each flight instrument component corresponding with the selected time on the slider:

    % Find corresponding time data entry
    k = find(app.simdata(:,1)<=t);
    k = k(end);
                
           app.Altimeter.Altitude = convlength(-app.simdata(k,4), 'm', 'ft');
           app.HeadingIndicator.Heading = convang(app.simdata(k,7),'rad','deg');
           app.ArtificialHorizon.Roll = convang(app.simdata(k,5),'rad','deg');
           app.ArtificialHorizon.Pitch = convang(app.simdata(k,6),'rad','deg');
                
           if k>1
               % Estimate velocity and angular rates
               Vel = (app.simdata(k,2:4)-app.simdata(k-1,2:4))/(app.simdata(k,1)-app.simdata(k-1,1));
               rates = (app.simdata(k,5:7)-app.simdata(k-1,5:7))/(app.simdata(k,1)-app.simdata(k-1,1));
                   
               app.AirspeedIndicator.Airspeed = convvel(sqrt(sum(Vel.^2)),'m/s','kts');
               app.ClimbIndicator.ClimbRate = convvel(-Vel(3),'m/s','ft/min');
    
               % Estimate turn rate and slip behavior 
               app.TurnCoordinator.Turn = convangvel(rates(1)*sind(30) + rates(3)*cosd(30),'rad/s','deg/s');
               app.TurnCoordinator.Slip = 1/(2*pi)*convang(atan(rates(3)*sqrt(sum(Vel.^2))/9.81)-app.simdata(k,5),'rad','deg');
           else
               % time = 0
               app.ClimbIndicator.ClimbRate = 0;
               app.AirspeedIndicator.Airspeed = 0;
               app.TurnCoordinator.Slip = 0;
               app.TurnCoordinator.Turn = 0;
           end
  5. Under the previously added code, add code to update the animation window display,:

    %% Update animation window display
    app.animObj.updateBodies(app.simdata(k,1));
    app.animObj.updateCamera(app.simdata(k,1));

Add Code to Close the Animation Window with UIfigure Window

  1. Add a CloseRequestFcn function. In the code view for the app, place the cursor after the properties section for FlightInstrumentsFlightDataPlaybackUIFigure and, in the Insert section, click Callback.

    The Add Callback Function dialog box displays.

  2. In the Add Callback Function dialog box:

    1. From the Callback list, select CloseRequestFcn.

    2. In the Name parameter, enter a name for the close function, for example FlightInstrumentsFlightDataPlaybackUIFigureCloseRequest.

      A callbacks section is added.

  3. In the new callback template, add code to delete the animation object, such as:

    % Close animation figure with app
    delete(app.animObj);
    delete(app);

Save and Run the App

To save and run the app:

  1. Save the app with the file name myFlightInstrumentsExample. Note that this name is applied to the classdef.

  2. Click Run.

    After saving your changes, you can run the app from the App Designer window, or by typing its name (without the .mlapp extension) at the MATLAB Command Window. When you run the app from the command prompt, the file must be in the current folder or on the MATLAB path.

    Left pane contains flight instruments pane with flight data in the. Right pane contains aircraft body.

  3. To visualize the saved flight data, change the slider position. Observe the flight instruments as the aircraft changes orientation in the animation window.

For a complete example, see Aerospace Flight Instruments in App Designer.

See Also

Functions

Properties

Topics