www.gusucode.com > ros 工具箱 matlab源码程序 > ros/+robotics/+ros/+msggen/+capabilities/Capability.m
classdef Capability < robotics.ros.Message %Capability MATLAB implementation of capabilities/Capability % This class was automatically generated by % robotics.ros.msg.internal.gen.MessageClassGenerator. % Copyright 2014-2016 The MathWorks, Inc. %#ok<*INUSD> properties (Constant) MessageType = 'capabilities/Capability' % The ROS message type end properties (Constant, Hidden) MD5Checksum = '05f9dd41875315c324efdf915b0e33a9' % The MD5 Checksum of the message definition end properties (Access = protected) JavaMessage % The Java message object end properties (Dependent) Capability_ Provider end properties (Constant, Hidden) PropertyList = {'Capability_', 'Provider'} % List of non-constant message properties ROSPropertyList = {'capability', 'provider'} % List of non-constant ROS message properties end methods function obj = Capability(msg) %Capability Construct the message object Capability import com.mathworks.toolbox.robotics.ros.message.MessageInfo; % Support default constructor if nargin == 0 obj.JavaMessage = obj.createNewJavaMessage; return; end % Construct appropriate empty array if isempty(msg) obj = obj.empty(0,1); return; end % Make scalar construction fast if isscalar(msg) % Check for correct input class if ~MessageInfo.compareTypes(msg(1), obj.MessageType) error(message('robotics:ros:message:NoTypeMatch', obj.MessageType, ... char(MessageInfo.getType(msg(1))) )); end obj.JavaMessage = msg(1); return; end % Check that this is a vector of scalar messages. Since this % is an object array, use arrayfun to verify. if ~all(arrayfun(@isscalar, msg)) error(message('robotics:ros:message:MessageArraySizeError')); end % Check that all messages in the array have the correct type if ~all(arrayfun(@(x) MessageInfo.compareTypes(x, obj.MessageType), msg)) error(message('robotics:ros:message:NoTypeMatchArray', obj.MessageType)); end % Construct array of objects if necessary objType = class(obj); for i = 1:length(msg) obj(i,1) = feval(objType, msg(i)); %#ok<AGROW> end end function capability_ = get.Capability_(obj) %get.Capability_ Get the value for property Capability_ capability_ = char(obj.JavaMessage.getCapability); end function set.Capability_(obj, capability_) %set.Capability_ Set the value for property Capability_ validateattributes(capability_, {'char'}, {}, 'Capability', 'Capability_'); obj.JavaMessage.setCapability(capability_); end function provider = get.Provider(obj) %get.Provider Get the value for property Provider provider = char(obj.JavaMessage.getProvider); end function set.Provider(obj, provider) %set.Provider Set the value for property Provider validateattributes(provider, {'char'}, {}, 'Capability', 'Provider'); obj.JavaMessage.setProvider(provider); end end methods (Access = protected) function cpObj = copyElement(obj) %copyElement Implements deep copy behavior for message % Call default copy method for shallow copy cpObj = copyElement@robotics.ros.Message(obj); % Create a new Java message object cpObj.JavaMessage = obj.createNewJavaMessage; % Iterate over all primitive properties cpObj.Capability_ = obj.Capability_; cpObj.Provider = obj.Provider; end function reload(obj, strObj) %reload Called by loadobj to assign properties obj.Capability_ = strObj.Capability_; obj.Provider = strObj.Provider; end end methods (Access = ?robotics.ros.Message) function strObj = saveobj(obj) %saveobj Implements saving of message to MAT file % Return an empty element if object array is empty if isempty(obj) strObj = struct.empty; return end strObj.Capability_ = obj.Capability_; strObj.Provider = obj.Provider; end end methods (Static, Access = {?matlab.unittest.TestCase, ?robotics.ros.Message}) function obj = loadobj(strObj) %loadobj Implements loading of message from MAT file % Return an empty object array if the structure element is not defined if isempty(strObj) obj = robotics.ros.msggen.capabilities.Capability.empty(0,1); return end % Create an empty message object obj = robotics.ros.msggen.capabilities.Capability; obj.reload(strObj); end end end