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

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

?? fun.c

?? 機器人足球,是用c語言實現的。大概有兩千行
?? C
字號:
int WhetherInView(Football *ball,Robot *dubu);
int WhetherInSide(Football *ball,Robot *dubu);
int TurnToBall(Football *ball,Robot *dubu);
int MoveToBall(Football *ball,Robot *dubu);
int DrawBall(Football *ball);
int DrawRobot(Robot *dubu);
int MeetBoundary(Football *ball,FootballPitch *pitch);
int MeetRobot(Football *ball,Robot *dubu);
int WhetherReverse(Robot *dubu);
int ReverseToGoal(Football *ball,Robot *dubu);
int ComputeShootAngle(Football *ball,Robot *dubu);
int ReverseFactor(Football *ball,Robot *dubu);

/*判斷球是否在機器人的正前方*/
int WhetherInView(Football *ball,Robot *dubu)
{
    float x1,y1,x2,y2,a1,a2,b1,b2,c1,c2;

    x1 = dubu->position_x + dubu->reverse_radius * cos(PI / 4 + dubu->direction_indicator);
    y1 = dubu->position_y - dubu->reverse_radius * sin(PI / 4 + dubu->direction_indicator);
    x2 = dubu->position_x + dubu->reverse_radius * cos(3 * PI / 4 + dubu->direction_indicator);
    y2 = dubu->position_y - dubu->reverse_radius * sin(3 * PI / 4 + dubu->direction_indicator);
    a1 = y2 - y1;
    b1 = x1 - x2;
    c1 = x2 * y1 - x1 * y2;

    x1 = dubu->position_x + dubu->reverse_radius * cos(5 * PI / 4 + dubu->direction_indicator);
    y1 = dubu->position_y - dubu->reverse_radius * sin(5 * PI / 4 + dubu->direction_indicator);
    x2 = dubu->position_x + dubu->reverse_radius * cos(7 * PI / 4 + dubu->direction_indicator);
    y2 = dubu->position_y - dubu->reverse_radius * sin(7 * PI / 4 + dubu->direction_indicator);
    a2 = y2 - y1;
    b2 = x1 - x2;
    c2 = x2 * y1 - x1 * y2;

    if((a1 * ball->ball_x + b1 * ball->ball_y + c1) * (a2 * ball->ball_x + b2 * ball->ball_y + c2) > 0)
        return 0;
    else    return 1;
}

/*判斷球是否在機器人的側面*/
int WhetherInSide(Football *ball,Robot *dubu)
{
    float x1,y1,x2,y2,a1,a2,b1,b2,c1,c2;

    x1 = dubu->position_x + dubu->reverse_radius * cos(PI / 4 + dubu->direction_indicator);
    y1 = dubu->position_y - dubu->reverse_radius * sin(PI / 4 + dubu->direction_indicator);
    x2 = dubu->position_x + dubu->reverse_radius * cos(7 * PI / 4 + dubu->direction_indicator);
    y2 = dubu->position_y - dubu->reverse_radius * sin(7 * PI / 4 + dubu->direction_indicator);
    a1 = y2 - y1;
    b1 = x1 - x2;
    c1 = x2 * y1 - x1 * y2;

    x1 = dubu->position_x + dubu->reverse_radius * cos(3 * PI / 4 + dubu->direction_indicator);
    y1 = dubu->position_y - dubu->reverse_radius * sin(3 * PI / 4 + dubu->direction_indicator);
    x2 = dubu->position_x + dubu->reverse_radius * cos(5 * PI / 4 + dubu->direction_indicator);
    y2 = dubu->position_y - dubu->reverse_radius * sin(5 * PI / 4 + dubu->direction_indicator);
    a2 = y2 - y1;
    b2 = x1 - x2;
    c2 = x2 * y1 - x1 * y2;

    if((a1 * ball->ball_x + b1 * ball->ball_y + c1) * (a2 * ball->ball_x + b2 * ball->ball_y + c2) > 0)
        return 0;
    else    return 1;
}

/*機器人向球的方向旋轉*/
int TurnToBall(Football *ball,Robot *dubu)
{
    float angle;

    if(ball->ball_x > dubu->position_x && ball->ball_y <= dubu->position_y)
    {
        dubu->direction = 0;
        dubu->position_x += dubu->small_speed * cos(dubu->decline);
        dubu->position_y -= dubu->small_speed * sin(dubu->decline);
        dubu->reverse_factor=ReverseFactor(ball,dubu);
        dubu->direction_indicator += dubu->reverse_factor * dubu->decline;
        if(dubu->direction_indicator >= 2 * PI)
            dubu->direction_indicator -= 2 * PI;
    }
    else if(ball->ball_x < dubu->position_x && ball->ball_y <= dubu->position_y)
    {
        dubu->direction = -PI;
        dubu->position_x -= dubu->small_speed * cos(dubu->decline);
        dubu->position_y -= dubu->small_speed * sin(dubu->decline);
        dubu->reverse_factor = ReverseFactor(ball,dubu);
        dubu->direction_indicator += dubu->reverse_factor * dubu->decline;
    }
    else if(ball->ball_x < dubu->position_x && ball->ball_y > dubu->position_y)
    {
        dubu->direction = -PI;
        dubu->position_x -= dubu->small_speed * cos(dubu->decline);
        dubu->position_y += dubu->small_speed * sin(dubu->decline);
        dubu->reverse_factor = ReverseFactor(ball,dubu);
        dubu->direction_indicator += dubu->reverse_factor * dubu->decline;
    }
    else if(ball->ball_x > dubu->position_x && ball->ball_y > dubu->position_y)
    {
        dubu->direction = -2*PI;
        dubu->position_x += dubu->small_speed * cos(dubu->decline);
        dubu->position_y += dubu->small_speed * sin(dubu->decline);
        dubu->reverse_factor = ReverseFactor(ball,dubu);
        dubu->direction_indicator += dubu->reverse_factor * dubu->decline;
        if(dubu->direction_indicator < 0)
            dubu->direction_indicator += 2 * PI;
    }
    else if(ball->ball_x == dubu->position_x && ball->ball_y < dubu->position_y)
    {
        dubu->direction = PI/2;
        dubu->position_x -= dubu->small_speed * cos(dubu->decline);
        dubu->position_y -= dubu->small_speed * sin(dubu->decline);
        dubu->reverse_factor = ReverseFactor(ball,dubu);
        dubu->direction_indicator += dubu->reverse_factor * dubu->decline;
    }
    else if(ball->ball_x == dubu->position_x && ball->ball_y > dubu->position_y)
    {
        dubu->direction = PI/2;
        dubu->position_x -= dubu->small_speed * cos(dubu->decline);
        dubu->position_y += dubu->small_speed * sin(dubu->decline);
        dubu->reverse_factor = ReverseFactor(ball,dubu);
        dubu->direction_indicator += dubu->reverse_factor * dubu->decline;
    }

    return 0;
}

/*當機器人對準了球時,正對著球前進*/
int MoveToBall(Football *ball,Robot *dubu)
{
    float x,y,d1,d2;

    x = dubu->position_x + dubu->forward_speed * cos(dubu->direction_indicator);
    y = dubu->position_y - dubu->forward_speed * sin(dubu->direction_indicator);
    d1 = (x - ball->ball_x) * (x - ball->ball_x) + (y - ball->ball_y) * (y - ball->ball_y);
    d2 = (dubu->position_x - ball->ball_x) * (dubu->position_x - ball->ball_x) + (dubu->position_y - ball->ball_y) * (dubu->position_y - ball->ball_y);
    if(d1 < d2)
    {
        dubu->position_x += dubu->forward_speed * cos(dubu->direction_indicator);
        dubu->position_y -= dubu->forward_speed * sin(dubu->direction_indicator);
    }
    else
    {
        dubu->position_x -= dubu->forward_speed * cos(dubu->direction_indicator);
        dubu->position_y += dubu->forward_speed * sin(dubu->direction_indicator);
    }

    return 0;
}

/*畫球的函數*/
int DrawBall(Football *ball)
{
    setfillstyle(1,ball->color);
    circle(ball->ball_x,ball->ball_y,ball->radius);
    floodfill(ball->ball_x,ball->ball_y,ball->color);

    return 0;
}

/*畫機器人的函數*/
int DrawRobot(Robot *dubu)
{
    setcolor(dubu->color);
    line(dubu->position_x + dubu->reverse_radius * cos ( PI / 4 + dubu->direction_indicator),dubu->position_y-dubu->reverse_radius*sin(PI/4+dubu->direction_indicator),dubu->position_x+dubu->reverse_radius*cos(3*PI/4+dubu->direction_indicator),dubu->position_y-dubu->reverse_radius*sin(3*PI/4+dubu->direction_indicator));
    line(dubu->position_x + dubu->reverse_radius * cos ( 3 * PI / 4 + dubu->direction_indicator),dubu->position_y-dubu->reverse_radius*sin(3*PI/4+dubu->direction_indicator),dubu->position_x+dubu->reverse_radius*cos(5*PI/4+dubu->direction_indicator),dubu->position_y-dubu->reverse_radius*sin(5*PI/4+dubu->direction_indicator));
    line(dubu->position_x + dubu->reverse_radius * cos ( 5 * PI / 4 + dubu->direction_indicator),dubu->position_y-dubu->reverse_radius*sin(5*PI/4+dubu->direction_indicator),dubu->position_x+dubu->reverse_radius*cos(7*PI/4+dubu->direction_indicator),dubu->position_y-dubu->reverse_radius*sin(7*PI/4+dubu->direction_indicator));
    line(dubu->position_x + dubu->reverse_radius * cos ( 7 * PI / 4 + dubu->direction_indicator),dubu->position_y-dubu->reverse_radius*sin(7*PI/4+dubu->direction_indicator),dubu->position_x+dubu->reverse_radius*cos(PI/4+dubu->direction_indicator),dubu->position_y-dubu->reverse_radius*sin(PI/4+dubu->direction_indicator));
    setfillstyle(1,dubu->color);
    floodfill(dubu->position_x,dubu->position_y,dubu->color);
    settextstyle(0,0,1);
    settextjustify(1,1);
    setcolor(WHITE);
    if(dubu->number == 1)
        outtextxy(dubu->position_x,dubu->position_y,"1");
    if(dubu->number == 2)
        outtextxy(dubu->position_x,dubu->position_y,"2");
    return 0;
}

/*二人足球中,機器人面對球門時,先判斷是否是自己要射的門,再決定是否執行射門動作*/
int WhetherReverse(Robot *dubu)
{
    int result;
    float a1,a2;

    if(dubu->direction_indicator >= 0 && dubu->direction_indicator < PI / 2)
        dubu->direction_indicator += 2 * PI;
    if(dubu->direction_indicator >= PI / 2 && dubu->direction_indicator < 3 * PI / 2)
    {
        a1 = PI + atan((dubu->position_y - 200) / (70 - dubu->position_x));
        a2 = PI + atan((dubu->position_y - 250) / (70 - dubu->position_x));
        if(dubu->direction_indicator > a1 && dubu->direction_indicator < a2 && dubu->number == 2)
            result = 0;
        else    result = 1;
    }
    else
    {
        a1 = 2 * PI + atan((dubu->position_y - 250) / (570 - dubu->position_x));
        a2 = 2 * PI + atan((dubu->position_y - 200) / (570 - dubu->position_x));
        if(dubu->direction_indicator > a1 && dubu->direction_indicator < a2 && dubu->number == 1)
            result = 0;
        else    result = 1;
    }
    if(dubu->direction_indicator > 2 * PI)
        dubu->direction_indicator -= 2 * PI;
    else if(dubu->direction_indicator < 0)
        dubu->direction_indicator += 2 * PI;

    return result;
}

/*射門動作的實現*/
int ReverseToGoal(Football *ball,Robot *dubu)
{
    int i,size;
    void *buffer;

    for(i=0;i<3;i++)
    {
        if(i==250)
            dubu->reverse_factor = -dubu->reverse_factor;
        dubu->direction_indicator += 16 * dubu->reverse_factor * dubu->decline;
        size = imagesize(dubu->position_x - dubu->reverse_radius,dubu->position_y - dubu->reverse_radius,dubu->position_x + dubu->reverse_radius,dubu->position_y + dubu->reverse_radius);
        buffer = malloc(size);
        getimage(dubu->position_x - dubu->reverse_radius,dubu->position_y - dubu->reverse_radius,dubu->position_x + dubu->reverse_radius,dubu->position_y + dubu->reverse_radius,buffer);
        if(buffer==0)
        {
            printf("error");
            exit(1);
        }
        DrawRobot(dubu);
        delay(2);
        putimage(dubu->position_x - dubu->reverse_radius,dubu->position_y - dubu->reverse_radius,buffer,COPY_PUT);
        free(buffer);
    }

    return 0;
}

/*二人足球中,判斷機器人的旋轉方向*/
int ComputeShootAngle(Football *ball,Robot *dubu)
{
    dubu->reverse_factor = -1;
    if(dubu->number == 1)
    {
        if(ball->ball_y >= dubu->position_y)
            dubu->reverse_factor = -1;
        else if(ball->ball_y < dubu->position_y)
            dubu->reverse_factor = 1;
    }
    if(dubu->number == 2)
    {
        if(ball->ball_y >= dubu->position_y)
            dubu->reverse_factor = 1;
        else if(ball->ball_y < dubu->position_y)
            dubu->reverse_factor = -1;
    }

    return 0;
}

/*計算機器人的旋轉方向,順時針為-1,逆時針為1*/
int ReverseFactor(Football *ball,Robot *dubu)
{
    int result;
    float angle;

    if(ball->ball_x > dubu->position_x && ball->ball_y <= dubu->position_y)
    {
        angle = atan((ball->ball_y - dubu->position_y) / (dubu->position_x - ball->ball_x));
        if((dubu->direction_indicator > 3 * PI / 2) && (dubu->direction_indicator < 2 * PI))
            result = 1;
        else if(dubu->direction_indicator < angle)
            result = 1;
        else    result = -1;
    }
    else if(ball->ball_x < dubu->position_x && ball->ball_y <= dubu->position_y)
    {
        angle = PI + atan((ball->ball_y - dubu->position_y) / (dubu->position_x - ball->ball_x));
        if(dubu->direction_indicator < angle)
            result = 1;
        else    result = -1;
    }
    else if(ball->ball_x < dubu->position_x && ball->ball_y > dubu->position_y)
    {
        angle = PI + atan((ball->ball_y - dubu->position_y) / (dubu->position_x - ball->ball_x));
        if(dubu->direction_indicator < angle)
            result = 1;
        else    result = -1;
    }
    else if(ball->ball_x > dubu->position_x && ball->ball_y > dubu->position_y)
    {
        angle = 2 * PI + atan((ball->ball_y - dubu->position_y) / (dubu->position_x - ball->ball_x));
        if((dubu->direction_indicator >= 0) && (dubu->direction_indicator < PI / 2))
            result = -1;
        else if(dubu->direction_indicator < angle)
            result = 1;
        else    result = -1;
    }
    else if(ball->ball_x == dubu->position_x && ball->ball_y < dubu->position_y)
    {
        angle = PI / 2;
        if(dubu->direction_indicator < angle)
            result = 1;
        else    result = -1;
    }
    else if(ball->ball_x == dubu->position_x && ball->ball_y > dubu->position_y)
    {
        angle = 3 * PI / 2;
        if(dubu->direction_indicator < angle)
            result = 1;
        else    result = -1;
    }

    return result;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
26uuu国产电影一区二区| 欧美一区二区精品久久911| 久久99精品一区二区三区三区| 亚洲精品欧美二区三区中文字幕| 国产精品久久久久永久免费观看 | 久久精品久久精品| 日韩影院精彩在线| 久久精品国产99国产| 国模娜娜一区二区三区| 国产91丝袜在线播放九色| av动漫一区二区| 在线这里只有精品| 欧美一区二区三区不卡| 久久综合av免费| 亚洲婷婷在线视频| 天堂精品中文字幕在线| 国产一区在线精品| 91色综合久久久久婷婷| 51久久夜色精品国产麻豆| 精品盗摄一区二区三区| 欧美国产禁国产网站cc| 亚洲高清免费观看| 极品尤物av久久免费看| 成人黄页毛片网站| 欧美肥妇毛茸茸| 亚洲国产激情av| 亚洲动漫第一页| 国产剧情一区二区| 日本乱人伦一区| 2023国产精品自拍| 一区二区三区精品| 国产精品1区2区| 欧美日韩中字一区| 国产嫩草影院久久久久| 一区二区三区欧美视频| 国产精品自拍网站| 欧美日韩大陆在线| 国产精品久久久久久一区二区三区 | 久久天天做天天爱综合色| 国产精品少妇自拍| 麻豆国产欧美一区二区三区| 99久久免费精品高清特色大片| 精品视频一区 二区 三区| 久久久国产一区二区三区四区小说 | xf在线a精品一区二区视频网站| 亚洲人成7777| 国产a久久麻豆| 欧美成人三级电影在线| 亚洲男人的天堂一区二区| 国产精品香蕉一区二区三区| 91麻豆精品久久久久蜜臀| 亚洲美女视频一区| 成人一级黄色片| 精品盗摄一区二区三区| 日韩福利电影在线| 欧美在线观看视频在线| 亚洲日本在线看| 风间由美性色一区二区三区| 久久综合久久综合亚洲| 奇米色一区二区| 精品视频一区三区九区| 亚洲一区二区中文在线| 97精品国产露脸对白| 亚洲欧美综合在线精品| 国产精品一二三四区| 欧美不卡视频一区| 日本亚洲电影天堂| 91精品国产入口| 美女网站色91| 欧美电视剧在线看免费| 久久99精品久久久久婷婷| 日韩一二三区视频| 久久国产精品第一页| 精品毛片乱码1区2区3区| 免播放器亚洲一区| 日韩一级免费观看| 激情图区综合网| 精品福利在线导航| 国产成人鲁色资源国产91色综| 日韩一区二区三| 国产精品正在播放| 欧美高清在线精品一区| 97se亚洲国产综合自在线| 亚洲欧洲一区二区三区| 91福利精品视频| 日韩高清中文字幕一区| 精品剧情在线观看| 大尺度一区二区| 一区二区三区高清在线| 91精品国产综合久久精品性色| 美女网站在线免费欧美精品| 久久久精品国产免大香伊| 91污片在线观看| 亚洲成人免费视| 精品国产乱码久久久久久浪潮| 国产麻豆视频一区二区| 中文字幕在线观看不卡视频| 91传媒视频在线播放| 麻豆91在线播放免费| 国产精品久久久久影院| 欧美手机在线视频| 狠狠色丁香婷婷综合久久片| 国产精品每日更新| 3atv一区二区三区| 国产传媒日韩欧美成人| 一区二区三区精品| 2023国产精品自拍| 91成人国产精品| 国产尤物一区二区| 亚洲国产综合在线| 久久蜜桃香蕉精品一区二区三区| 91色婷婷久久久久合中文| 免费在线观看视频一区| 亚洲精品ww久久久久久p站| 日韩美女视频一区二区在线观看| 99re视频这里只有精品| 久久av中文字幕片| 亚洲国产一区二区a毛片| 国产精品久久久久久久久免费桃花| 在线电影院国产精品| av在线一区二区三区| 精品一区二区三区视频 | 日韩三级在线免费观看| aaa欧美日韩| 国产乱妇无码大片在线观看| 亚洲超碰97人人做人人爱| 中文字幕免费不卡在线| 精品va天堂亚洲国产| 欧美日韩高清一区二区不卡| 91色乱码一区二区三区| 国产成人av一区二区三区在线观看| 秋霞av亚洲一区二区三| 亚洲444eee在线观看| 亚洲婷婷国产精品电影人久久| 久久精品人人做人人综合| 日韩一区二区在线看片| 欧美日韩精品三区| 欧美三级日本三级少妇99| 99这里只有精品| 99久久精品国产一区二区三区| 国产福利一区二区三区| 国产在线视频一区二区三区| 日产精品久久久久久久性色| 午夜精品一区二区三区电影天堂| 一区二区三区四区在线免费观看| 亚洲天堂中文字幕| 亚洲欧美日韩综合aⅴ视频| 国产精品美女久久久久久久| 欧美经典一区二区三区| 国产欧美综合在线| 国产女同性恋一区二区| 亚洲欧洲在线观看av| 最新国产の精品合集bt伙计| 亚洲青青青在线视频| 亚洲精品国产视频| 一二三区精品视频| 亚洲午夜电影在线观看| 亚洲成人手机在线| 美国av一区二区| 国产精品亚洲а∨天堂免在线| 国产精品综合av一区二区国产馆| 成人av电影在线观看| 日本乱码高清不卡字幕| 欧美一区二区三区四区五区 | 日本女人一区二区三区| 男男成人高潮片免费网站| 国产一区二区主播在线| av一区二区三区四区| 91麻豆国产自产在线观看| 欧美色男人天堂| 91精品国产欧美一区二区| 久久综合国产精品| 亚洲啪啪综合av一区二区三区| 亚洲成人午夜电影| 韩国精品在线观看| 99国产精品一区| 欧美一区二区三区播放老司机| 久久久综合九色合综国产精品| 国产精品丝袜一区| 天天影视涩香欲综合网 | 一区二区三区中文免费| 日本aⅴ亚洲精品中文乱码| 国产精品一二一区| 欧美性生活久久| 亚洲精品一区二区在线观看| 综合欧美一区二区三区| 久久精品99久久久| 成人h版在线观看| 日韩欧美自拍偷拍| 亚洲欧美偷拍三级| 国产精品2024| 日韩一区二区麻豆国产| 亚洲猫色日本管| 国产激情一区二区三区| 在线电影欧美成精品| 国产精品无人区| 久久se这里有精品| 在线观看免费视频综合| 国产亚洲1区2区3区| 五月婷婷综合激情|