⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 fakecam.c

📁 卡耐基.梅隆大学的机器人仿真软件(Redhat linux 9下安装)
💻 C
字号:
 /********************************************************* * * This source code is part of the Carnegie Mellon Robot * Navigation Toolkit (CARMEN) * * CARMEN Copyright (c) 2002 Michael Montemerlo, Nicholas * Roy, Sebastian Thrun, Dirk Haehnel, Cyrill Stachniss, * and Jared Glover * * CARMEN 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. * * CARMEN 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 CARMEN; if not, write to the * Free Software Foundation, Inc., 59 Temple Place,  * Suite 330, Boston, MA  02111-1307 USA * ********************************************************/#include <carmen/carmen.h>#include <assert.h>#include "img3.xpm"#include "../camera_hw_interface.h"static carmen_camera_image_t saved_image;int lookup_colour(char *xpm_ptr, char *colour_table[], int num_colours){  int i;  for (i = 0; i < num_colours; i++) {    if (strncmp(xpm_ptr, colour_table[i], 2) == 0)       return strtol(colour_table[i]+6, NULL, 16);  }  return 0;}carmen_camera_image_t *carmen_camera_start(int argc __attribute__ ((unused)), 					   char **argv __attribute__ ((unused))){  carmen_camera_image_t *image;  char *xpm_ptr;  char *image_ptr;  int x, y;  long int colour;  int num_colours;    sscanf(img3[0], "%d %d %d", &(saved_image.width), &(saved_image.height),	 &num_colours);  saved_image.bytes_per_pixel = 3;  saved_image.image_size = saved_image.width*saved_image.height*    saved_image.bytes_per_pixel;  saved_image.is_new = 0;  saved_image.timestamp = 0;  saved_image.image = (char *)calloc(saved_image.image_size, sizeof(char));  carmen_test_alloc(saved_image.image);  image_ptr = saved_image.image;  for (y = 0; y < saved_image.height; y++) {    xpm_ptr = img3[num_colours+y+1];    for (x = 0; x < saved_image.width; x++) {          colour = lookup_colour(xpm_ptr, img3+1, num_colours);          image_ptr[0] = (colour >> 16) & 0xFF;      image_ptr[1] = (colour >> 8) & 0xFF;      image_ptr[2] = colour & 0xFF;            xpm_ptr += 2;      image_ptr += 3;    }  }    image = (carmen_camera_image_t *)calloc(1, sizeof(carmen_camera_image_t));  memcpy(image, &saved_image, sizeof(carmen_camera_image_t));  image->image = (char *)calloc(image->image_size, sizeof(char));  carmen_test_alloc(image->image);  memcpy(image->image, saved_image.image, sizeof(char)*image->image_size);  return image;}void carmen_camera_shutdown(void){}void carmen_camera_grab_image(carmen_camera_image_t *image){  memcpy(image->image, saved_image.image, sizeof(char)*image->image_size);  image->timestamp = carmen_get_time();  image->is_new = 1;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -