亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? visiondevice.cc

?? 一個機器人平臺
?? CC
?? 第 1 頁 / 共 2 頁
字號:
/* *  Stage : a multi-robot simulator. *  Copyright (C) 2001, 2002 Richard Vaughan, Andrew Howard and Brian Gerkey. * *  This program is free software; you can redistribute it and/or modify *  it under the terms of the GNU General Public License as published by *  the Free Software Foundation; either version 2 of the License, or *  (at your option) any later version. * *  This program is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *  GNU General Public License for more details. * *  You should have received a copy of the GNU General Public License *  along with this program; if not, write to the Free Software *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * *//* * Desc: Device to simulate the ACTS vision system. * Author: Richard Vaughan, Andrew Howard * Date: 28 Nov 2000 * CVS info: $Id: visiondevice.cc,v 1.3 2002/11/11 08:21:40 rtv Exp $ */#include <math.h>#include <iostream>#include "world.hh"#include "visiondevice.hh"#include "ptzdevice.hh"#include "raytrace.hh"#define DEBUG///////////////////////////////////////////////////////////////////////////// Default constructorCVisionDevice::CVisionDevice(LibraryItem* libit,CWorld *world, CPtzDevice *parent)        : CPlayerEntity( libit, world, parent ){  // set the Player IO sizes correctly for this type of Entity  m_data_len    = sizeof( player_blobfinder_data_t );   m_command_len = 0;  m_config_len  = 0;  m_reply_len  = 0;   m_player.code = PLAYER_BLOBFINDER_CODE;  m_interval = 0.1; // 10Hz - the real cam is around this  // If the parent is a ptz device we will use it, otherwise  // we will operate as a naked vision device.  if (parent->m_player.code == PLAYER_PTZ_CODE )    m_ptz_device = parent;  else    m_ptz_device = NULL;    cameraImageWidth = 160;  cameraImageHeight = 120;  m_scan_width = 160;  m_pan = 0;  m_tilt = 0;  m_zoom = DTOR(60);  m_max_range = 8.0;  // Set the default channel-color mapping for ACTS.  Let's start with  // a reasonable set of color channels these get overwritten when  // specifiedby the worldfile.  this->channels[0] = ::LookupColor( "red" );  this->channels[1] = ::LookupColor( "green" );  this->channels[2] = ::LookupColor( "blue" );  this->channels[3] = ::LookupColor( "yellow" );  this->channels[4] = ::LookupColor( "cyan" );  this->channels[5] = ::LookupColor( "magenta" );  this->channel_count = 6;  numBlobs = 0;  memset( blobs, 0, MAXBLOBS * sizeof( ColorBlob ) );#ifdef INCLUDE_RTK2  vision_fig = NULL;#endif}///////////////////////////////////////////////////////////////////////////// Startup routine//bool CVisionDevice::Startup(){  if (!CPlayerEntity::Startup())    return false;  return true;}///////////////////////////////////////////////////////////////////////////// Load the entity from the worldfilebool CVisionDevice::Load(CWorldFile *worldfile, int section){  if (!CPlayerEntity::Load(worldfile, section))    return false;  // Read the vision channel/color mapping  for (int i = 0; true; i++)  {    const char *color = worldfile->ReadTupleString(section, "channels", i, NULL);    if( color ) // if the string looks ok    {      //printf( "[%d:%s]", i, color );      this->channels[i] = ::LookupColor(color);      this->channel_count = i + 1;    }    else      break;  }    return true;}///////////////////////////////////////////////////////////////////////////// Update the laser data//void CVisionDevice::Update( double sim_time ){  ASSERT(m_world != NULL);  CPlayerEntity::Update( sim_time );  // Dont update anything if we are not subscribed  if( Subscribed() < 1 )    return;    // See if its time to recalculate vision  if( sim_time - m_last_update < m_interval )    return;  m_last_update = sim_time;    //RTK_TRACE0("generating new data");    // Generate the scan-line image  UpdateScan();    // Generate ACTS data    player_blobfinder_data_t data;  memset( &data, 0, sizeof(data) );  UpdateACTS( &data );    // Copy data to the output buffer  PutData( &data, sizeof(data) );}///////////////////////////////////////////////////////////////////////////// Generate the scan-line imagevoid CVisionDevice::UpdateScan(){  // Get the camera's global pose  double ox, oy, oth;  GetGlobalPose(ox, oy, oth);  // Get the ptz settings  if (m_ptz_device != NULL)    m_ptz_device->GetPTZ(m_pan, m_tilt, m_zoom);  // Compute starting angle  oth = oth + m_pan + m_zoom / 2;  // Compute fov, range, etc  double dth = m_zoom / m_scan_width;  // Make sure the data buffer is big enough  ASSERT((size_t)m_scan_width<=sizeof(m_scan_channel)/sizeof(m_scan_channel[0]));  // TODO  //int skip = (int) (m_world->m_vision_res / m_scan_res - 0.5);  // Do each scan  // Note that the scan is taken *clockwise*  // i'm scanning this as half-resolution for a significant speed-up  StageColor col;    for (int s = 0; s < m_scan_width; s++)  {    //printf( "scan %d of %d\n", s, m_scan_width );    // indicate no valid color found (MSB normally unused in 32bit RGB value)    col = 0xFF000000;           // Compute parameters of scan line    double px = ox;    double py = oy;    double pth = oth - s * dth;       CLineIterator lit( px, py, pth, m_max_range,                        m_world->ppm, m_world->matrix, PointToBearingRange );          CEntity* ent;    double range = m_max_range;          while( (ent = lit.GetNextEntity()) )     {      //printf( "ent %p (%s), vision_return %d\n",      //ent, ent->lib_entry->token, ent->vision_return );      //ent->Print( "" );      // Ignore itself, its ancestors and its descendents      if( ent == this || this->IsDescendent(ent) || ent->IsDescendent(this))	  continue;           // Ignore transparent things      if( !ent->vision_return )	  continue;      range = lit.GetRange(); // it's this far away      // get the color of the entity      memcpy( &col, &(ent->color), sizeof( StageColor ) );	        break;    }	    // initialize the reading     m_scan_channel[s] = 0; // channel 0 is no-blob    m_scan_range[s] = 0;    // if we found a color on this ray    if( !(col & 0xFF000000) )     {      // look up this color in the color/channel mapping array      for( int c=0; c < this->channel_count; c++ )      {        if( this->channels[c] == col)        {          //printf("color %d is channel %d\n", col, c);          //printf("m_scan_channel[%d] = %d\n", s, c+1);          m_scan_channel[s] = c + 1; // channel 0 is no-blob          m_scan_range[s] = range;          break;        }      }    }  }}///////////////////////////////////////////////////////////////////////////// Generate ACTS data from scan-line imagesize_t CVisionDevice::UpdateACTS( player_blobfinder_data_t* data ){  PRINT_DEBUG( "entered" );  assert( data );  // now the colors and ranges are filled in - time to do blob detection  float yRadsPerPixel = m_zoom / cameraImageHeight;  int blobleft = 0, blobright = 0;  unsigned char blobcol = 0;  int blobtop = 0, blobbottom = 0;  numBlobs = 0;  // scan through the samples looking for color blobs  for( int s=0; s < m_scan_width; s++ )  {    if( m_scan_channel[s] != 0 && m_scan_channel[s] <         PLAYER_BLOBFINDER_MAX_CHANNELS)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费在线观看不卡| 综合久久久久久久| 精品视频一区三区九区| 色综合色综合色综合| 成人午夜大片免费观看| 国产aⅴ综合色| 国产精品99久久久久| 国产一区激情在线| 国产精品一区专区| 国产精一区二区三区| 国产成人在线色| 成人精品免费看| 成人av在线一区二区| 成人蜜臀av电影| 色综合久久久久久久久久久| 日本韩国精品在线| 欧美精三区欧美精三区| 欧美一区午夜精品| 精品国产一区二区在线观看| 久久蜜桃av一区二区天堂| 久久久久高清精品| 亚洲三级小视频| 视频一区二区中文字幕| 精品影视av免费| 成人网在线播放| 欧美亚洲高清一区二区三区不卡| 欧美日本高清视频在线观看| 91精品免费在线| 国产亚洲欧美中文| 亚洲人一二三区| 毛片av一区二区三区| 成人黄色免费短视频| 日本精品一区二区三区四区的功能| 欧美性极品少妇| 久久久久97国产精华液好用吗 | 亚洲精品国产视频| 日韩黄色片在线观看| 国产激情一区二区三区| 在线观看日韩高清av| 日韩精品中文字幕在线不卡尤物| 欧美经典一区二区| 五月天丁香久久| 成人午夜av电影| 欧美一级黄色录像| 亚洲欧美日韩久久精品| 国产一区二区三区四区五区美女 | 国产精品女同一区二区三区| 亚洲va欧美va人人爽午夜 | 国产欧美精品一区二区三区四区 | 日本午夜精品一区二区三区电影| 国产91丝袜在线18| 欧美一区二区视频免费观看| 亚洲视频香蕉人妖| 国产精品18久久久久久久网站| 欧美私人免费视频| 中文字幕中文字幕一区二区 | 国产精品一区二区在线观看网站| 一本色道a无线码一区v| 欧美国产一区在线| 久久aⅴ国产欧美74aaa| 欧美三级视频在线观看| 国产精品黄色在线观看| 国产成人精品免费一区二区| 欧美一区二区啪啪| 亚洲一区二区三区四区五区黄| 成人午夜碰碰视频| 久久久99精品免费观看| 国产在线看一区| 制服.丝袜.亚洲.中文.综合| 一区二区三区美女视频| 色综合视频一区二区三区高清| 国产亲近乱来精品视频| 国产99久久久久| 国产精品美女视频| 国产成人精品三级麻豆| 国产亚洲精品久| 国产成人在线看| 欧美国产欧美综合| 大胆亚洲人体视频| 一区精品在线播放| 99精品热视频| 一区二区三区小说| 欧美午夜精品久久久| 亚洲高清三级视频| 91精品国产麻豆| 紧缚捆绑精品一区二区| 久久久久99精品国产片| 东方aⅴ免费观看久久av| 国产精品少妇自拍| 91视频你懂的| 亚洲尤物在线视频观看| 欧美色图激情小说| 美日韩一区二区| 久久久精品免费网站| 波多野结衣视频一区| 亚洲精品国产a久久久久久| 日本精品免费观看高清观看| 亚欧色一区w666天堂| 日韩免费高清视频| 丁香天五香天堂综合| 亚洲蜜臀av乱码久久精品蜜桃| 欧美午夜视频网站| 极品少妇一区二区| 国产精品免费久久| 欧美日韩一区高清| 国产精品一区二区男女羞羞无遮挡| 国产精品区一区二区三区| 色久优优欧美色久优优| 青青草91视频| 国产精品毛片高清在线完整版| 91福利精品第一导航| 理论电影国产精品| 亚洲毛片av在线| 精品国产乱码91久久久久久网站| bt欧美亚洲午夜电影天堂| 午夜久久久久久久久| 国产午夜一区二区三区| 欧美四级电影网| 丰满亚洲少妇av| 日产国产欧美视频一区精品| 国产精品久久久久久福利一牛影视 | 欧美一区二区视频在线观看2022| 国产成人亚洲精品狼色在线| 亚洲成人动漫av| 国产精品久久久久永久免费观看 | 久久久久久久久一| 欧美日韩不卡视频| www.av精品| 久久国产精品一区二区| 亚洲制服欧美中文字幕中文字幕| 久久久亚洲国产美女国产盗摄 | 欧美xxx久久| 欧美最猛性xxxxx直播| 风间由美性色一区二区三区| 青青草原综合久久大伊人精品 | 日韩**一区毛片| 一个色在线综合| 国产精品初高中害羞小美女文| 精品欧美一区二区三区精品久久| 色婷婷综合久色| 成人av在线资源网站| 国产一级精品在线| 加勒比av一区二区| 毛片av一区二区三区| 天堂久久一区二区三区| 亚洲欧美日韩一区| 成人欧美一区二区三区1314| 久久先锋影音av| 久久夜色精品国产欧美乱极品| 欧美一区二区三区视频在线 | 精品一二三四区| 奇米色777欧美一区二区| 婷婷丁香激情综合| 亚洲成人自拍一区| 亚洲一区二区精品3399| 亚洲综合自拍偷拍| 亚洲影院久久精品| 亚洲国产成人tv| 亚洲一区二区视频在线| 亚洲一区二区视频| 午夜私人影院久久久久| 久久精品国产一区二区| 亚洲国产视频一区二区| 亚洲国产一区二区三区| 亚洲chinese男男1069| 首页国产欧美久久| 久久激情五月激情| 国产精品一区二区无线| 成人av综合在线| 欧美亚洲一区二区在线| 欧美裸体一区二区三区| 91精品国产色综合久久不卡蜜臀| 日韩欧美中文字幕公布| 久久精品免视看| 日韩毛片一二三区| 亚洲线精品一区二区三区八戒| 视频精品一区二区| 国产中文字幕精品| 91免费观看视频| 欧美一区二区视频网站| 国产视频一区二区在线| 亚洲精品国产一区二区三区四区在线| 亚洲国产视频一区| 国产专区欧美精品| 色乱码一区二区三区88| 欧美肥胖老妇做爰| 亚洲国产成人自拍| 亚洲国产欧美在线| 国产精品亚洲第一区在线暖暖韩国| 99久精品国产| 日韩美一区二区三区| 日韩一区在线看| 日韩精品亚洲一区二区三区免费| 国产精品正在播放| 欧美老女人第四色| 国产精品欧美经典| 久久se精品一区精品二区| 色婷婷av一区二区三区gif| 欧美va亚洲va香蕉在线| 一区二区三区中文字幕精品精品 |