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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? world.cpp

?? 機(jī)器人的行為控制模擬程序。用于機(jī)器人的環(huán)境識(shí)別。A robot action decision simulation used for robot enviroment recognition.
?? CPP
?? 第 1 頁 / 共 2 頁
字號(hào):
/* 
    Robot Simulator

    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.

    (C) 2006 Jason Hunt
    nulluser@gmail.gom 
*/

#include <windows.h>
#include <math.h>
#include <stdio.h>

#include "utility.h"
#include "graphics.h"
#include "main.h"
#include "console.h"
#include "robot.h"
#include "world.h"
#include "map.h"

world_type world;       // All world data 


/* Inital world setup */
void world_setup(void )
{   
    // Size in world space
    world.x_size = 10;
    world.y_size = 10;

    world_destroy(); // free any existing world

    // Create brushs
    world.white_brush = CreateSolidBrush(RGB(255, 255, 255));
    world.black_brush = CreateSolidBrush(RGB(0, 0, 0));
    world.green_brush = CreateSolidBrush(RGB(0, 255, 0));
    world.blue_brush = CreateSolidBrush(RGB(0, 0, 255));
    world.red_brush = CreateSolidBrush(RGB(255, 0, 0));
    world.color1_brush = CreateSolidBrush(RGB(0, 128, 200));
    

    // Create pens
    world.white_pen = CreatePen(PS_SOLID, 1, RGB(255, 255, 255));
    world.black_pen = CreatePen(PS_SOLID, 1, RGB(0, 0, 0));
    world.green_pen = CreatePen(PS_SOLID, 1, RGB(0, 255, 0));
    world.blue_pen = CreatePen(PS_SOLID, 1, RGB(0, 0, 255));
    world.color1_pen = CreatePen(PS_SOLID, 1, RGB(0, 128, 200));

    // Run time tweakable values
    world.scale1 = 0.11;
    world.scale2 = 0.86;
    world.scale3 = 0.193;
        
 
    // Start showing walls
    world.show_walls = true;
 

    // No walls
    world.walls = NULL;
    world.num_walls = 0;

    // No markers
    world.markers = NULL;

    // No Impacts
    world.impacts = NULL;

    // No waypoints
    world.waypoints = NULL;
    world.num_waypoints = 0;
    world.cur_waypoint = 0;

    // Do not draw grad grid
    world.draw_grad = false;
    
    
    world.target_enabled = true;
    world.target_x = world.x_size /2.0;
    world.target_y = world.y_size /2.0;
    
    
    // Setup surronding walls
    
    double wall_width = 0.05;
    
    // top
    world_add_wall(0, 0, world.x_size, wall_width);

    // Bottom
    world_add_wall(0, world.y_size-wall_width, world.x_size, wall_width);
    
    // Left
    world_add_wall(0, 0, wall_width, world.y_size);    
    
    // Right
    world_add_wall(world.x_size-wall_width, 0, wall_width, world.y_size);
    

    // Setup cross walls in center
   // world_add_wall(world.x_size/2 - world.x_size/4 , world.y_size/2-wall_width/2, world.x_size/2, wall_width);
   // world_add_wall(world.x_size/2-wall_width/2, world.y_size/2 - world.y_size/4 , wall_width, world.y_size/2);

    // Setup robot
    robot_init();


    // Compute first map interation
    world_compute_map_grid();
  
}
/* End of void world_setup(void ) */


/* Free all world data */
void world_destroy( void )
{
    world.num_walls = 0;
    
    world_free_walls();    
    world_free_markers();
    world_free_impacts();
    world_free_waypoints();
    
    DeleteObject(world.black_brush);
    DeleteObject(world.white_brush);
    DeleteObject(world.green_brush);
    DeleteObject(world.blue_brush);
    DeleteObject(world.red_brush);
    DeleteObject(world.color1_brush);
    
    DeleteObject(world.white_pen);
    DeleteObject(world.black_pen);
    DeleteObject(world.green_pen);
    DeleteObject(world.blue_pen);
    DeleteObject(world.color1_pen);
    
}
/* End of world_destroy */



/* Draw entire world */
void world_draw( HDC dc )
{

    SelectObject(dc, world.white_pen);
    SelectObject(dc, world.white_brush);
      
    // Clear entire area
    Rectangle(dc, 0, 0, display_x, display_y);


    if (world.draw_grad)
        world_draw_grad(dc);



//    if (world.draw_grad)
//         world_draw_map_grid(dc);


    SelectObject(dc, world.black_pen);
    SelectObject(dc, world.white_brush);

    world_draw_markers(dc);




    if (world.show_walls)
        world_draw_walls(dc);

    if (world.target_enabled)
    {
        double target_size = 0.15;

        SelectObject(dc, world.green_brush);        

        Ellipse(dc, get_screen_x(world.target_x - target_size/2), 
                    get_screen_y(world.target_y - target_size/2), 
                    get_screen_x(world.target_x + target_size/2), 
                    get_screen_y(world.target_y + target_size/2));
                
    }    


    world_draw_impacts(dc);    

    world_draw_waypoints(dc);

    robot_draw(dc);
    
}
/* End of world_draw */


/* Update all world data */
void world_update( void )
{
 //   world_compute_map_grid();

    robot_update();
}
/* End of world_update */


    
/* Transform from world space to screen space */
int get_screen_x( double x )
{
    return((int)(x / (double) world.x_size * display_x));
}
/* End of get_screen_x */


/* Transform from world space to screen space */
int get_screen_y( double y )
{
    return((int)(y / (double) world.y_size * display_y));
}
/* End of get_screen_y */


/* Return world cords of a screen pos */
double get_world_x( unsigned int x)
{
    return((x / (double)display_x) * world.x_size);        
}
/* End of get_world_x */

/* Return world cords of a screen pos */
double get_world_y( unsigned int y)
{
    return((y / (double)display_y) * world.y_size);        
}
/* End of get_world_x */


/* Return a bounting box in screen space for an object */
void get_bounding_rect(double x, double y, double x_size, double y_size, RECT &r)
{
    r.left = get_screen_x(x - x_size / 2);
    r.top = get_screen_y(y - y_size / 2);
    r.right = get_screen_x(x + x_size / 2);
    r.bottom = get_screen_y(y + y_size / 2);
}
/* End of get_bounding_rect */
    


/* Return true if points is inside of wall */    
bool world_check_wall_point( double x, double y )
{
    wall_type *w = world.walls;

    while (w != NULL) 
    {
        if (x >= w->x && x <= w->x + w->x_size && 
            y >= w->y && y <= w->y + w->y_size)
            return(1);

        w = w->next;

    }
    return(false);
}    
/* End of world_check_wall_point */


/* Add a wall to the world */
void world_add_wall(double x, double y, double x_size, double y_size)
{
    wall_type *w = world.walls;
    
    world.walls = (wall_type *) malloc(sizeof(wall_type));

    world.walls->x = x;
    world.walls->y = y;

    world.walls->x_size = x_size;
    world.walls->y_size = y_size;
       
    world.walls->next = w;
    
    world.num_walls++;
}
/* End of world_add_wall */



/* Free wall memory */
void world_free_walls( void )
{
    wall_type *tmp;
        
    while (world.walls != NULL) 
    {
        tmp = world.walls->next;

        free(world.walls);

        world.walls = tmp; // Unlink
    }

    world.num_walls = 0;
}    
/* End of world_free walls */


    
/* Draw walls to DC */
void world_draw_walls( HDC dc )
{
    wall_type *tmp = world.walls;

    SelectObject(dc, (HBRUSH)world.color1_brush);
    SelectObject(dc, (HPEN)world.color1_pen);

    while (tmp != NULL) 
    {
        RECT r;
        
        Rectangle(dc, get_screen_x(tmp->x),
                      get_screen_y(tmp->y),
                      get_screen_x(tmp->x + tmp->x_size),
                      get_screen_y(tmp->y + tmp->y_size));

        tmp = tmp->next;
    }
}    
/* End of world_draw_walls */



/* Add waypoint to nav system */
void world_add_waypoint(double x, double y, double dir)
{
    waypoint_type *w = world.waypoints;
    
    world.waypoints = (waypoint_type *) malloc(sizeof(waypoint_type));

    world.waypoints->x = x;
    world.waypoints->y = y;
    world.waypoints->dir = dir;
      
    world.waypoints->next = w;
    
    world.num_waypoints++;
}
/* End of world_add_waypoint */


/* Free waypoint memory */
void world_free_waypoints( void )
{
    waypoint_type *tmp;
        
    while (world.waypoints != NULL) 
    {
        tmp = world.waypoints->next;

        free(world.waypoints);

        world.waypoints = tmp; // Unlink
    }
    world.num_waypoints = 0;
}    
/* End of world_free_waypoints */


/* Draw nav waypoints to DC */
void world_draw_waypoints( HDC dc )
{
    waypoint_type *tmp = world.waypoints;

    SelectObject(dc, (HBRUSH)world.color1_brush);
    SelectObject(dc, (HPEN)world.color1_pen);

    while (tmp != NULL) 
    {
        RECT r;

        if (tmp->num == world.cur_waypoint)
        {
           SelectObject(dc, (HBRUSH)world.red_brush);
           SelectObject(dc, (HPEN)world.black_pen);
            
            
        }else
        {
           SelectObject(dc, (HBRUSH)world.color1_brush);
           SelectObject(dc, (HPEN)world.color1_pen);
        }
        
        Ellipse(dc, get_screen_x(tmp->x - 0.05),
                      get_screen_y(tmp->y - 0.05),
                      get_screen_x(tmp->x  + 0.05),
                      get_screen_y(tmp->y  + 0.05));

        tmp = tmp->next;

    }
}
/* End of draw waypoints */

    

/* Add marker to the world */
void world_add_marker(double x, double y)
{
    return;
    marker_type *m = world.markers;
    
    world.markers = (marker_type *) malloc(sizeof(marker_type));

    world.markers->x = x;
    world.markers->y = y;
       
    world.markers->next = m;
}
/* End of world_add_marker */



/* Free marker memory */
void world_free_markers( void )
{
    marker_type *tmp;
        
    while (world.markers != NULL) 
    {
        tmp = world.markers->next;


        free(world.markers);

        world.markers = tmp; // Unlink
    }
}    
/* End of world free markers */


/* draw markers to DC */
void world_draw_markers( HDC dc )
{
    marker_type *m = world.markers;

return;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲免费大片在线观看| 亚洲第一av色| 久久久精品一品道一区| 欧美三级韩国三级日本一级| 波多野结衣视频一区| 国产精品白丝jk白祙喷水网站 | 亚洲第一av色| 亚洲电影激情视频网站| 亚洲自拍另类综合| 亚洲国产综合视频在线观看| 亚洲一区二区三区四区五区中文| 亚洲色图第一区| 亚洲日本成人在线观看| 亚洲视频小说图片| 夜夜精品视频一区二区 | 日韩激情在线观看| 亚洲大尺度视频在线观看| 亚洲福利视频一区二区| 性久久久久久久久久久久| 日本欧洲一区二区| 久久国产日韩欧美精品| 黑人巨大精品欧美一区| 国产美女精品在线| 成人免费视频视频在线观看免费 | 色婷婷激情综合| 在线免费精品视频| 91精品麻豆日日躁夜夜躁| 欧美成人精品1314www| 久久毛片高清国产| 中文字幕中文乱码欧美一区二区| 亚洲精品国产一区二区三区四区在线| 亚洲最新视频在线观看| 日韩av电影免费观看高清完整版 | 99精品黄色片免费大全| 欧美视频一二三区| 欧美成人性战久久| 亚洲国产激情av| 亚洲永久精品大片| 麻豆成人91精品二区三区| 国产精品综合视频| 在线日韩一区二区| 精品欧美一区二区三区精品久久| 欧美高清在线一区| 亚洲成av人在线观看| 精品在线免费视频| 一本色道久久加勒比精品| 欧美三级在线看| 久久这里只有精品视频网| 自拍视频在线观看一区二区| 天天综合日日夜夜精品| 国产99久久久国产精品| 欧美日韩中文一区| 国产日韩三级在线| 亚洲妇女屁股眼交7| 国产精品1区2区| 欧美日韩亚洲综合| 欧美国产激情二区三区| 日本一区中文字幕| 99精品偷自拍| 精品免费一区二区三区| 亚洲精品日日夜夜| 国产毛片一区二区| 欧美日韩免费电影| 国产精品久久久久aaaa樱花| 青草国产精品久久久久久| 99久久国产综合精品女不卡| 日韩视频免费观看高清完整版 | 国产色产综合色产在线视频| 亚洲精品日韩专区silk| 国产毛片精品国产一区二区三区| 欧美亚洲动漫制服丝袜| 中文字幕乱码久久午夜不卡 | 成人免费视频免费观看| 在线成人免费观看| 亚洲另类春色校园小说| 国产精品影音先锋| 91精品国产色综合久久不卡蜜臀 | 亚洲少妇中出一区| 国产乱码精品一区二区三区忘忧草| 欧洲精品一区二区| 国产精品美女久久福利网站| 蜜臀精品一区二区三区在线观看| 91福利国产成人精品照片| 中文字幕乱码一区二区免费| 国产一区视频导航| 日韩精品一区二区三区蜜臀| 亚洲成人精品一区| 色婷婷激情久久| 亚洲欧洲日韩在线| 成人午夜电影久久影院| 久久一区二区视频| 经典三级在线一区| 日韩免费性生活视频播放| 天堂在线一区二区| 欧美色中文字幕| 亚洲国产一二三| 欧美视频第二页| 亚洲国产精品久久久久秋霞影院| 一本久久精品一区二区| 亚洲欧美一区二区三区国产精品| 国产成人精品在线看| 久久蜜桃av一区二区天堂| 国内精品免费在线观看| 日韩欧美一级片| 裸体一区二区三区| 日韩精品中午字幕| 精品中文字幕一区二区小辣椒 | 亚洲成人综合视频| 欧美日韩国产精选| 日本不卡高清视频| 日韩精品一区二区三区在线观看| 久久狠狠亚洲综合| 久久久美女毛片 | 国产喷白浆一区二区三区| 国产成人精品亚洲午夜麻豆| 亚洲国产成人一区二区三区| 97久久超碰国产精品| 亚洲欧美视频在线观看视频| 色婷婷综合久久久中文字幕| 一区av在线播放| 欧美高清视频www夜色资源网| 亚洲妇女屁股眼交7| 日韩午夜三级在线| 国产激情一区二区三区| 国产精品欧美久久久久一区二区| 99久久婷婷国产综合精品电影| 国产精品成人网| 欧美日韩在线直播| 捆绑调教一区二区三区| 久久久久久久久蜜桃| 99视频精品免费视频| 亚洲专区一二三| 精品久久久久久最新网址| 国产高清在线精品| 亚洲美女偷拍久久| 91精品国产入口| 国产福利视频一区二区三区| 亚洲日本欧美天堂| 欧美高清视频一二三区| 国产精品69久久久久水密桃| 亚洲人妖av一区二区| 欧美高清视频一二三区| 国产精品一区在线观看你懂的| 国产精品国产精品国产专区不蜜| 欧美性videosxxxxx| 精品在线观看免费| 亚洲人成网站色在线观看| 欧美一卡二卡三卡| 成人国产精品免费观看| 性做久久久久久久免费看| 久久久久高清精品| 欧美日韩在线播放一区| 国产原创一区二区| 亚洲综合成人在线视频| 欧美成人国产一区二区| 91在线小视频| 久久99精品久久久久久国产越南 | 欧美色成人综合| 国产成人免费9x9x人网站视频| 亚洲国产欧美在线| 久久久久国产精品麻豆ai换脸 | 91精品91久久久中77777| 另类小说色综合网站| 中文字幕在线不卡一区二区三区| 欧美日韩精品一区视频| 成人91在线观看| 另类小说一区二区三区| 亚洲精选一二三| 欧美系列日韩一区| 欧美精品一区二区三区很污很色的| 日韩一级片网站| 国产精品女人毛片| 亚洲一线二线三线视频| 日韩一卡二卡三卡四卡| 久久久国际精品| 国产精品羞羞答答xxdd| 蜜乳av一区二区三区| 一个色综合av| 色婷婷av一区二区三区软件| 极品少妇xxxx偷拍精品少妇| 欧美性大战久久| 精品国产麻豆免费人成网站| 9191成人精品久久| 最新高清无码专区| 成人毛片老司机大片| 午夜精彩视频在线观看不卡| 91麻豆精品国产91久久久久| 六月丁香综合在线视频| 欧美一区二区三区爱爱| 久久影院午夜片一区| 亚洲国产欧美在线人成| 香蕉影视欧美成人| 丰满白嫩尤物一区二区| 国产风韵犹存在线视精品| 欧美日韩精品系列| 亚洲精品第一国产综合野| 捆绑调教美女网站视频一区| 日韩亚洲欧美在线| 免费人成黄页网站在线一区二区 | 6080午夜不卡|