00001 // -*- C++ -*- 00010 #ifndef COLOR_EXTRACTOR_H 00011 #define COLOR_EXTRACTOR_H 00012 00013 #include <rtm/idl/BasicDataType.hh> 00014 #include <rtm/idl/ExtendedDataTypes.hh> 00015 #include "hrpsys/idl/Img.hh" 00016 #include <rtm/Manager.h> 00017 #include <rtm/DataFlowComponentBase.h> 00018 #include <rtm/CorbaPort.h> 00019 #include <rtm/DataInPort.h> 00020 #include <rtm/DataOutPort.h> 00021 #include <rtm/idl/BasicDataTypeSkel.h> 00022 #include <cv.h> 00023 00024 // Service implementation headers 00025 // <rtc-template block="service_impl_h"> 00026 00027 // </rtc-template> 00028 00029 // Service Consumer stub headers 00030 // <rtc-template block="consumer_stub_h"> 00031 00032 // </rtc-template> 00033 00034 using namespace RTC; 00035 00039 class ColorExtractor 00040 : public RTC::DataFlowComponentBase 00041 { 00042 public: 00047 ColorExtractor(RTC::Manager* manager); 00051 virtual ~ColorExtractor(); 00052 00053 // The initialize action (on CREATED->ALIVE transition) 00054 // formaer rtc_init_entry() 00055 virtual RTC::ReturnCode_t onInitialize(); 00056 00057 // The finalize action (on ALIVE->END transition) 00058 // formaer rtc_exiting_entry() 00059 // virtual RTC::ReturnCode_t onFinalize(); 00060 00061 // The startup action when ExecutionContext startup 00062 // former rtc_starting_entry() 00063 // virtual RTC::ReturnCode_t onStartup(RTC::UniqueId ec_id); 00064 00065 // The shutdown action when ExecutionContext stop 00066 // former rtc_stopping_entry() 00067 // virtual RTC::ReturnCode_t onShutdown(RTC::UniqueId ec_id); 00068 00069 // The activated action (Active state entry action) 00070 // former rtc_active_entry() 00071 virtual RTC::ReturnCode_t onActivated(RTC::UniqueId ec_id); 00072 00073 // The deactivated action (Active state exit action) 00074 // former rtc_active_exit() 00075 virtual RTC::ReturnCode_t onDeactivated(RTC::UniqueId ec_id); 00076 00077 // The execution action that is invoked periodically 00078 // former rtc_active_do() 00079 virtual RTC::ReturnCode_t onExecute(RTC::UniqueId ec_id); 00080 00081 // The aborting action when main logic error occurred. 00082 // former rtc_aborting_entry() 00083 // virtual RTC::ReturnCode_t onAborting(RTC::UniqueId ec_id); 00084 00085 // The error action in ERROR state 00086 // former rtc_error_do() 00087 // virtual RTC::ReturnCode_t onError(RTC::UniqueId ec_id); 00088 00089 // The reset action that is invoked resetting 00090 // This is same but different the former rtc_init_entry() 00091 // virtual RTC::ReturnCode_t onReset(RTC::UniqueId ec_id); 00092 00093 // The state update action that is invoked after onExecute() action 00094 // no corresponding operation exists in OpenRTm-aist-0.2.0 00095 // virtual RTC::ReturnCode_t onStateUpdate(RTC::UniqueId ec_id); 00096 00097 // The action that is invoked when execution context's rate is changed 00098 // no corresponding operation exists in OpenRTm-aist-0.2.0 00099 // virtual RTC::ReturnCode_t onRateChanged(RTC::UniqueId ec_id); 00100 00101 00102 protected: 00103 // Configuration variable declaration 00104 // <rtc-template block="config_declare"> 00105 00106 // </rtc-template> 00107 00108 Img::TimedCameraImage m_original; 00109 00110 // DataInPort declaration 00111 // <rtc-template block="inport_declare"> 00112 InPort<Img::TimedCameraImage> m_originalIn; 00113 00114 // </rtc-template> 00115 00116 Img::TimedCameraImage m_result; 00117 RTC::TimedPoint2D m_pos; 00118 00119 // DataOutPort declaration 00120 // <rtc-template block="outport_declare"> 00121 OutPort<Img::TimedCameraImage> m_resultOut; 00122 OutPort<RTC::TimedPoint2D> m_posOut; 00123 00124 // </rtc-template> 00125 00126 // CORBA Port declaration 00127 // <rtc-template block="corbaport_declare"> 00128 00129 // </rtc-template> 00130 00131 // Service declaration 00132 // <rtc-template block="service_declare"> 00133 00134 // </rtc-template> 00135 00136 // Consumer declaration 00137 // <rtc-template block="consumer_declare"> 00138 00139 // </rtc-template> 00140 00141 private: 00142 IplImage *m_img; 00143 int m_minPixels; 00144 std::vector<int> m_rgbRegion; 00145 int dummy; 00146 }; 00147 00148 00149 extern "C" 00150 { 00151 void ColorExtractorInit(RTC::Manager* manager); 00152 }; 00153 00154 #endif // COLOR_EXTRACTOR_H