www.gusucode.com > ros 工具箱 matlab源码程序 > ros/+robotics/+ros/+msggen/+geographic_msgs/BoundingBox.m
classdef BoundingBox < robotics.ros.Message %BoundingBox MATLAB implementation of geographic_msgs/BoundingBox % This class was automatically generated by % robotics.ros.msg.internal.gen.MessageClassGenerator. % Copyright 2014-2016 The MathWorks, Inc. %#ok<*INUSD> properties (Constant) MessageType = 'geographic_msgs/BoundingBox' % The ROS message type end properties (Constant, Hidden) MD5Checksum = 'f62e8b5e390a3ac7603250d46e8f8446' % The MD5 Checksum of the message definition end properties (Access = protected) JavaMessage % The Java message object end properties (Constant, Access = protected) GeographicMsgsGeoPointClass = robotics.ros.msg.internal.MessageFactory.getClassForType('geographic_msgs/GeoPoint') % Dispatch to MATLAB class for message type geographic_msgs/GeoPoint end properties (Dependent) MinPt MaxPt end properties (Access = protected) Cache = struct('MinPt', [], 'MaxPt', []) % The cache for fast data access end properties (Constant, Hidden) PropertyList = {'MaxPt', 'MinPt'} % List of non-constant message properties ROSPropertyList = {'max_pt', 'min_pt'} % List of non-constant ROS message properties end methods function obj = BoundingBox(msg) %BoundingBox Construct the message object BoundingBox 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 minpt = get.MinPt(obj) %get.MinPt Get the value for property MinPt if isempty(obj.Cache.MinPt) obj.Cache.MinPt = feval(obj.GeographicMsgsGeoPointClass, obj.JavaMessage.getMinPt); end minpt = obj.Cache.MinPt; end function set.MinPt(obj, minpt) %set.MinPt Set the value for property MinPt validateattributes(minpt, {obj.GeographicMsgsGeoPointClass}, {'nonempty', 'scalar'}, 'BoundingBox', 'MinPt'); obj.JavaMessage.setMinPt(minpt.getJavaObject); % Update cache if necessary if ~isempty(obj.Cache.MinPt) obj.Cache.MinPt.setJavaObject(minpt.getJavaObject); end end function maxpt = get.MaxPt(obj) %get.MaxPt Get the value for property MaxPt if isempty(obj.Cache.MaxPt) obj.Cache.MaxPt = feval(obj.GeographicMsgsGeoPointClass, obj.JavaMessage.getMaxPt); end maxpt = obj.Cache.MaxPt; end function set.MaxPt(obj, maxpt) %set.MaxPt Set the value for property MaxPt validateattributes(maxpt, {obj.GeographicMsgsGeoPointClass}, {'nonempty', 'scalar'}, 'BoundingBox', 'MaxPt'); obj.JavaMessage.setMaxPt(maxpt.getJavaObject); % Update cache if necessary if ~isempty(obj.Cache.MaxPt) obj.Cache.MaxPt.setJavaObject(maxpt.getJavaObject); end end end methods (Access = protected) function resetCache(obj) %resetCache Resets any cached properties obj.Cache.MinPt = []; obj.Cache.MaxPt = []; end function cpObj = copyElement(obj) %copyElement Implements deep copy behavior for message % Call default copy method for shallow copy cpObj = copyElement@robotics.ros.Message(obj); % Clear any existing cached properties cpObj.resetCache; % Create a new Java message object cpObj.JavaMessage = obj.createNewJavaMessage; % Recursively copy compound properties cpObj.MinPt = copy(obj.MinPt); cpObj.MaxPt = copy(obj.MaxPt); end function reload(obj, strObj) %reload Called by loadobj to assign properties obj.MinPt = feval([obj.GeographicMsgsGeoPointClass '.loadobj'], strObj.MinPt); obj.MaxPt = feval([obj.GeographicMsgsGeoPointClass '.loadobj'], strObj.MaxPt); 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.MinPt = saveobj(obj.MinPt); strObj.MaxPt = saveobj(obj.MaxPt); 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.geographic_msgs.BoundingBox.empty(0,1); return end % Create an empty message object obj = robotics.ros.msggen.geographic_msgs.BoundingBox; obj.reload(strObj); end end end