• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            Cpper
            C/C++高級(jí)工程師 Android高級(jí)軟件工程師 IT集成工程師 音頻工程師 熟悉c,c++,java,c#,py,js,asp等多種語(yǔ)言 程序猿

            最近考慮開(kāi)發(fā)一款兵棋軟件,名字都想好了,叫犀牛兵棋,打算支持四邊形地圖和六邊形地圖。

            前者比較好說(shuō),后者在根據(jù)屏幕坐標(biāo)計(jì)算格子坐標(biāo)的時(shí)候,稍微有點(diǎn)麻煩。

            先說(shuō)下我們的坐標(biāo)系是x軸向右,y軸向上,原點(diǎn)在左下角。

            格子地圖坐標(biāo)如下



            根據(jù)格子坐標(biāo)計(jì)算出對(duì)應(yīng)世界坐標(biāo)系的函數(shù)如下




            QPointF GridCell6Manager::getWorldPosByCellCoordinate(
            int x,int y)

            {

            if (x % 2 == 0)

            return QPointF(1.5f*res*(x+1),

            (
            0.5*R3+R3*y)*res);

            return QPointF(1.5f*res*(x + 1),

            (R3 
            + y * R3)*res);

            }



            QPoint GridCell6Manager::getCellCoordinateByWorldPos(
            int x,int y)

            {

            QPoint point(
            -1,-1);

            float xpos = x-res*0.5f;

            float ypos = y/(R3*res) - 0.5f;

            int yset[2= {std::floorf(ypos),std::ceilf(ypos)};

            xpos 
            /= (1.5*World::getInstance().getWorldResolution());

            int xset[2= { std::floorf(xpos),std::ceilf(xpos)};

            auto p00 
            = getWorldPosByCellCoordinate(xset[0],yset[0]);

            auto p01 
            = getWorldPosByCellCoordinate(xset[0],yset[1]);

            auto p10 
            = getWorldPosByCellCoordinate(xset[1],yset[0]);

            auto p11 
            = getWorldPosByCellCoordinate(xset[1],yset[1]);

            float d00 = distance2<float>(x,y,p00.x(),p00.y());

            float d01 = distance2<float>(x,y,p01.x(),p01.y());

            float d10 = distance2<float>(x,y,p10.x(),p10.y());

            float d11 = distance2<float>(x,y,p11.x(),p11.y());

            int i,j;

            if(d00 < d01 && d00 < d10 && d00 < d11)

            {

            = xset[0];

            = yset[0];

            }

            else if(d00 > d01 && d01 < d10 && d01 < d11)

            {

            = xset[0];

            = yset[1];

            }

            else if(d10 < d00 && d10 < d01 && d10 < d11)

            {

            = xset[1];

            = yset[0];

            }

            else

            {

            = xset[1];

            = yset[1];

            }

            return QPoint(i,j);

            }
            其中res為格子邊長(zhǎng),R3為sqrt(3)常量

            在這個(gè)基礎(chǔ)上就可以計(jì)算從世界坐標(biāo)到格子坐標(biāo)的轉(zhuǎn)換了



            posted on 2019-06-18 09:35 ccsdu2009 閱讀(2272) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 編程基礎(chǔ)
             
            久久精品夜色噜噜亚洲A∨ | 久久综合九色综合网站| 国内精品久久国产大陆| 奇米综合四色77777久久| 天天躁日日躁狠狠久久| 99久久国产宗和精品1上映| 人妻系列无码专区久久五月天| 国产精品午夜久久| 久久久久香蕉视频| 中文成人无码精品久久久不卡 | 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 国产高潮国产高潮久久久| 久久久久久久女国产乱让韩| 欧美精品乱码99久久蜜桃| 色综合久久中文字幕无码| 久久国产精品成人影院| 2021国产成人精品久久| 久久精品这里只有精99品| 久久人人爽人人爽人人片AV高清 | 欧美久久一级内射wwwwww.| 国产69精品久久久久APP下载| 日韩久久久久久中文人妻| avtt天堂网久久精品| 久久久久女教师免费一区| 久久久久亚洲av成人网人人软件 | 亚洲va中文字幕无码久久不卡| 精品永久久福利一区二区| 国产精品免费久久久久久久久| 色综合久久中文字幕综合网| 欧美丰满熟妇BBB久久久| 激情五月综合综合久久69| 一本一本久久aa综合精品| 精品久久久久中文字| 亚洲AV无码久久| 久久久久亚洲AV成人网人人网站| 久久99久国产麻精品66| 日本免费久久久久久久网站| 777午夜精品久久av蜜臀| 99久久免费只有精品国产| 国色天香久久久久久久小说 | 国产麻豆精品久久一二三|