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

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

?? shptree.c

?? Source code, and some other odds and ends can be downloaded from http://shapelib.maptools.org/dl.
?? C
?? 第 1 頁 / 共 2 頁
字號:
        padfBoundsMax1[0] = padfBoundsMinIn[0] + dfRange * SHP_SPLIT_RATIO;        padfBoundsMin2[0] = padfBoundsMaxIn[0] - dfRange * SHP_SPLIT_RATIO;    }/* -------------------------------------------------------------------- *//*      Otherwise split in Y direction.                                 *//* -------------------------------------------------------------------- */    else    {        double	dfRange = padfBoundsMaxIn[1] - padfBoundsMinIn[1];        padfBoundsMax1[1] = padfBoundsMinIn[1] + dfRange * SHP_SPLIT_RATIO;        padfBoundsMin2[1] = padfBoundsMaxIn[1] - dfRange * SHP_SPLIT_RATIO;    }}/************************************************************************//*                       SHPTreeNodeAddShapeId()                        *//************************************************************************/static intSHPTreeNodeAddShapeId( SHPTreeNode * psTreeNode, SHPObject * psObject,                       int nMaxDepth, int nDimension ){    int		i;    /* -------------------------------------------------------------------- *//*      If there are subnodes, then consider wiether this object        *//*      will fit in them.                                               *//* -------------------------------------------------------------------- */    if( nMaxDepth > 1 && psTreeNode->nSubNodes > 0 )    {        for( i = 0; i < psTreeNode->nSubNodes; i++ )        {            if( SHPCheckObjectContained(psObject, nDimension,                                      psTreeNode->apsSubNode[i]->adfBoundsMin,                                      psTreeNode->apsSubNode[i]->adfBoundsMax))            {                return SHPTreeNodeAddShapeId( psTreeNode->apsSubNode[i],                                              psObject, nMaxDepth-1,                                              nDimension );            }        }    }/* -------------------------------------------------------------------- *//*      Otherwise, consider creating four subnodes if could fit into    *//*      them, and adding to the appropriate subnode.                    *//* -------------------------------------------------------------------- */#if MAX_SUBNODE == 4    else if( nMaxDepth > 1 && psTreeNode->nSubNodes == 0 )    {        double	adfBoundsMinH1[4], adfBoundsMaxH1[4];        double	adfBoundsMinH2[4], adfBoundsMaxH2[4];        double	adfBoundsMin1[4], adfBoundsMax1[4];        double	adfBoundsMin2[4], adfBoundsMax2[4];        double	adfBoundsMin3[4], adfBoundsMax3[4];        double	adfBoundsMin4[4], adfBoundsMax4[4];        SHPTreeSplitBounds( psTreeNode->adfBoundsMin,                            psTreeNode->adfBoundsMax,                            adfBoundsMinH1, adfBoundsMaxH1,                            adfBoundsMinH2, adfBoundsMaxH2 );        SHPTreeSplitBounds( adfBoundsMinH1, adfBoundsMaxH1,                            adfBoundsMin1, adfBoundsMax1,                            adfBoundsMin2, adfBoundsMax2 );        SHPTreeSplitBounds( adfBoundsMinH2, adfBoundsMaxH2,                            adfBoundsMin3, adfBoundsMax3,                            adfBoundsMin4, adfBoundsMax4 );        if( SHPCheckObjectContained(psObject, nDimension,                                    adfBoundsMin1, adfBoundsMax1)            || SHPCheckObjectContained(psObject, nDimension,                                    adfBoundsMin2, adfBoundsMax2)            || SHPCheckObjectContained(psObject, nDimension,                                    adfBoundsMin3, adfBoundsMax3)            || SHPCheckObjectContained(psObject, nDimension,                                    adfBoundsMin4, adfBoundsMax4) )        {            psTreeNode->nSubNodes = 4;            psTreeNode->apsSubNode[0] = SHPTreeNodeCreate( adfBoundsMin1,                                                           adfBoundsMax1 );            psTreeNode->apsSubNode[1] = SHPTreeNodeCreate( adfBoundsMin2,                                                           adfBoundsMax2 );            psTreeNode->apsSubNode[2] = SHPTreeNodeCreate( adfBoundsMin3,                                                           adfBoundsMax3 );            psTreeNode->apsSubNode[3] = SHPTreeNodeCreate( adfBoundsMin4,                                                           adfBoundsMax4 );            /* recurse back on this node now that it has subnodes */            return( SHPTreeNodeAddShapeId( psTreeNode, psObject,                                           nMaxDepth, nDimension ) );        }    }#endif /* MAX_SUBNODE == 4 *//* -------------------------------------------------------------------- *//*      Otherwise, consider creating two subnodes if could fit into     *//*      them, and adding to the appropriate subnode.                    *//* -------------------------------------------------------------------- */#if MAX_SUBNODE == 2    else if( nMaxDepth > 1 && psTreeNode->nSubNodes == 0 )    {        double	adfBoundsMin1[4], adfBoundsMax1[4];        double	adfBoundsMin2[4], adfBoundsMax2[4];        SHPTreeSplitBounds( psTreeNode->adfBoundsMin, psTreeNode->adfBoundsMax,                            adfBoundsMin1, adfBoundsMax1,                            adfBoundsMin2, adfBoundsMax2 );        if( SHPCheckObjectContained(psObject, nDimension,                                 adfBoundsMin1, adfBoundsMax1))        {            psTreeNode->nSubNodes = 2;            psTreeNode->apsSubNode[0] = SHPTreeNodeCreate( adfBoundsMin1,                                                           adfBoundsMax1 );            psTreeNode->apsSubNode[1] = SHPTreeNodeCreate( adfBoundsMin2,                                                           adfBoundsMax2 );            return( SHPTreeNodeAddShapeId( psTreeNode->apsSubNode[0], psObject,                                           nMaxDepth - 1, nDimension ) );        }        else if( SHPCheckObjectContained(psObject, nDimension,                                         adfBoundsMin2, adfBoundsMax2) )        {            psTreeNode->nSubNodes = 2;            psTreeNode->apsSubNode[0] = SHPTreeNodeCreate( adfBoundsMin1,                                                           adfBoundsMax1 );            psTreeNode->apsSubNode[1] = SHPTreeNodeCreate( adfBoundsMin2,                                                           adfBoundsMax2 );            return( SHPTreeNodeAddShapeId( psTreeNode->apsSubNode[1], psObject,                                           nMaxDepth - 1, nDimension ) );        }    }#endif /* MAX_SUBNODE == 2 *//* -------------------------------------------------------------------- *//*      If none of that worked, just add it to this nodes list.         *//* -------------------------------------------------------------------- */    psTreeNode->nShapeCount++;    psTreeNode->panShapeIds =        SfRealloc( psTreeNode->panShapeIds,                   sizeof(int) * psTreeNode->nShapeCount );    psTreeNode->panShapeIds[psTreeNode->nShapeCount-1] = psObject->nShapeId;    if( psTreeNode->papsShapeObj != NULL )    {        psTreeNode->papsShapeObj =            SfRealloc( psTreeNode->papsShapeObj,                       sizeof(void *) * psTreeNode->nShapeCount );        psTreeNode->papsShapeObj[psTreeNode->nShapeCount-1] = NULL;    }    return TRUE;}/************************************************************************//*                         SHPTreeAddShapeId()                          *//*                                                                      *//*      Add a shape to the tree, but don't keep a pointer to the        *//*      object data, just keep the shapeid.                             *//************************************************************************/int SHPAPI_CALLSHPTreeAddShapeId( SHPTree * psTree, SHPObject * psObject ){    return( SHPTreeNodeAddShapeId( psTree->psRoot, psObject,                                   psTree->nMaxDepth, psTree->nDimension ) );}/************************************************************************//*                      SHPTreeCollectShapesIds()                       *//*                                                                      *//*      Work function implementing SHPTreeFindLikelyShapes() on a       *//*      tree node by tree node basis.                                   *//************************************************************************/void SHPAPI_CALLSHPTreeCollectShapeIds( SHPTree *hTree, SHPTreeNode * psTreeNode,                        double * padfBoundsMin, double * padfBoundsMax,                        int * pnShapeCount, int * pnMaxShapes,                        int ** ppanShapeList ){    int		i;    /* -------------------------------------------------------------------- *//*      Does this node overlap the area of interest at all?  If not,    *//*      return without adding to the list at all.                       *//* -------------------------------------------------------------------- */    if( !SHPCheckBoundsOverlap( psTreeNode->adfBoundsMin,                                psTreeNode->adfBoundsMax,                                padfBoundsMin,                                padfBoundsMax,                                hTree->nDimension ) )        return;/* -------------------------------------------------------------------- *//*      Grow the list to hold the shapes on this node.                  *//* -------------------------------------------------------------------- */    if( *pnShapeCount + psTreeNode->nShapeCount > *pnMaxShapes )    {        *pnMaxShapes = (*pnShapeCount + psTreeNode->nShapeCount) * 2 + 20;        *ppanShapeList = (int *)            SfRealloc(*ppanShapeList,sizeof(int) * *pnMaxShapes);    }/* -------------------------------------------------------------------- *//*      Add the local nodes shapeids to the list.                       *//* -------------------------------------------------------------------- */    for( i = 0; i < psTreeNode->nShapeCount; i++ )    {        (*ppanShapeList)[(*pnShapeCount)++] = psTreeNode->panShapeIds[i];    }    /* -------------------------------------------------------------------- *//*      Recurse to subnodes if they exist.                              *//* -------------------------------------------------------------------- */    for( i = 0; i < psTreeNode->nSubNodes; i++ )    {        if( psTreeNode->apsSubNode[i] != NULL )            SHPTreeCollectShapeIds( hTree, psTreeNode->apsSubNode[i],                                    padfBoundsMin, padfBoundsMax,                                    pnShapeCount, pnMaxShapes,                                    ppanShapeList );    }}/************************************************************************//*                      SHPTreeFindLikelyShapes()                       *//*                                                                      *//*      Find all shapes within tree nodes for which the tree node       *//*      bounding box overlaps the search box.  The return value is      *//*      an array of shapeids terminated by a -1.  The shapeids will     *//*      be in order, as hopefully this will result in faster (more      *//*      sequential) reading from the file.                              *//************************************************************************/int SHPAPI_CALL1(*)SHPTreeFindLikelyShapes( SHPTree * hTree,                         double * padfBoundsMin, double * padfBoundsMax,                         int * pnShapeCount ){    int	*panShapeList=NULL, nMaxShapes = 0;    int	i, j;/* -------------------------------------------------------------------- *//*      Perform the search by recursive descent.                        *//* -------------------------------------------------------------------- */    *pnShapeCount = 0;    SHPTreeCollectShapeIds( hTree, hTree->psRoot,                            padfBoundsMin, padfBoundsMax,                            pnShapeCount, &nMaxShapes,                            &panShapeList );/* -------------------------------------------------------------------- *//*      For now I just use a bubble sort to order the shapeids, but     *//*      this should really be a quicksort.                              *//* -------------------------------------------------------------------- */    for( i = 0; i < *pnShapeCount-1; i++ )    {        for( j = 0; j < (*pnShapeCount) - i - 1; j++ )        {            if( panShapeList[j] > panShapeList[j+1] )            {                int	nTempId;                nTempId = panShapeList[j];                panShapeList[j] = panShapeList[j+1];                panShapeList[j+1] = nTempId;            }        }    }    return panShapeList;}/************************************************************************//*                          SHPTreeNodeTrim()                           *//*                                                                      *//*      This is the recurve version of SHPTreeTrimExtraNodes() that     *//*      walks the tree cleaning it up.                                  *//************************************************************************/static int SHPTreeNodeTrim( SHPTreeNode * psTreeNode ){    int		i;/* -------------------------------------------------------------------- *//*      Trim subtrees, and free subnodes that come back empty.          *//* -------------------------------------------------------------------- */    for( i = 0; i < psTreeNode->nSubNodes; i++ )    {        if( SHPTreeNodeTrim( psTreeNode->apsSubNode[i] ) )        {            SHPDestroyTreeNode( psTreeNode->apsSubNode[i] );            psTreeNode->apsSubNode[i] =                psTreeNode->apsSubNode[psTreeNode->nSubNodes-1];            psTreeNode->nSubNodes--;            i--; /* process the new occupant of this subnode entry */        }    }/* -------------------------------------------------------------------- *//*      We should be trimmed if we have no subnodes, and no shapes.     *//* -------------------------------------------------------------------- */    return( psTreeNode->nSubNodes == 0 && psTreeNode->nShapeCount == 0 );}/************************************************************************//*                       SHPTreeTrimExtraNodes()                        *//*                                                                      *//*      Trim empty nodes from the tree.  Note that we never trim an     *//*      empty root node.                                                *//************************************************************************/void SHPAPI_CALLSHPTreeTrimExtraNodes( SHPTree * hTree ){    SHPTreeNodeTrim( hTree->psRoot );}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产一区二区三区| 国产精品污网站| 久久久三级国产网站| 国产精品美女久久久久aⅴ国产馆| 国产精品国产三级国产有无不卡 | 午夜精品福利久久久| 免费看精品久久片| 91老师片黄在线观看| 精品成人佐山爱一区二区| 亚洲综合一区二区精品导航| 国产成人午夜精品影院观看视频| 欧美日韩美女一区二区| 中文字幕亚洲区| 国内精品免费**视频| 欧美精品在线一区二区| 亚洲免费三区一区二区| 国产精品系列在线观看| 欧美一区二区观看视频| 蜜臀av性久久久久av蜜臀妖精| 国产成a人亚洲精| 欧美草草影院在线视频| 天堂va蜜桃一区二区三区漫画版| 99久久伊人网影院| 久久夜色精品一区| 天天综合日日夜夜精品| 91麻豆国产香蕉久久精品| 国产情人综合久久777777| 久久99在线观看| 欧美日本高清视频在线观看| 亚洲欧美激情一区二区| 99视频精品免费视频| 中文无字幕一区二区三区| 国产精品一品二品| 久久久久久9999| 国产一区二区三区免费看| 2020国产精品自拍| 国产乱码精品一区二区三区av| 精品不卡在线视频| 国产一区二区导航在线播放| 精品国免费一区二区三区| 九九**精品视频免费播放| 精品久久久三级丝袜| 激情综合五月婷婷| 久久欧美一区二区| 国产69精品久久久久毛片| 国产精品免费看片| 色综合久久99| 亚洲成人一二三| 欧美一区中文字幕| 国产呦精品一区二区三区网站| 26uuu久久天堂性欧美| 国产精品香蕉一区二区三区| 国产精品美女视频| 欧美探花视频资源| 麻豆国产欧美日韩综合精品二区| 欧美精品一区二| www..com久久爱| 亚洲午夜av在线| 日韩免费电影网站| 处破女av一区二区| 一区二区三区在线观看网站| 欧美久久久久久久久中文字幕| 麻豆精品视频在线观看| 国产精品美女视频| 久久蜜臀中文字幕| av资源站一区| 日韩av电影免费观看高清完整版在线观看 | 成人黄色小视频在线观看| 亚洲人成网站精品片在线观看| 欧美日韩在线播| 国产一区二区不卡在线| 一区二区三区在线免费视频| 欧美成人女星排行榜| 91在线国产福利| 美女国产一区二区三区| 综合久久一区二区三区| 91精品国产乱码久久蜜臀| 国产精品影音先锋| 亚洲国产精品久久久久秋霞影院| 欧美变态tickle挠乳网站| 色综合色综合色综合| 久久精品国产**网站演员| 亚洲免费av观看| 26uuu精品一区二区在线观看| 色噜噜狠狠成人中文综合| 精品无人码麻豆乱码1区2区| 亚洲综合在线视频| 亚洲国产电影在线观看| 日韩一级大片在线| 在线观看www91| 国产69精品久久久久777| 婷婷成人综合网| 亚洲欧美电影一区二区| 国产亚洲va综合人人澡精品| 欧美精品v国产精品v日韩精品| 丁香婷婷深情五月亚洲| 麻豆精品国产91久久久久久| 亚洲高清视频在线| 亚洲精品中文字幕在线观看| 国产午夜精品久久久久久免费视| 日韩一级黄色大片| 制服丝袜亚洲播放| 欧美在线观看视频在线| 99视频精品免费视频| 成人午夜伦理影院| 国产原创一区二区三区| 另类小说欧美激情| 日韩av中文字幕一区二区三区| 亚洲国产成人精品视频| 亚洲精品视频在线观看免费| 国产精品久久久久久亚洲毛片| 久久九九全国免费| 久久久亚洲国产美女国产盗摄| 日韩精品自拍偷拍| 日韩精品一区在线观看| 日韩三级高清在线| 日韩欧美国产综合在线一区二区三区| 精品视频在线免费看| 欧美影院精品一区| 欧美视频完全免费看| 欧美日韩综合不卡| 欧美欧美欧美欧美| 337p亚洲精品色噜噜狠狠| 91精品国产综合久久婷婷香蕉 | 一区二区三区欧美| 亚洲免费三区一区二区| 一区二区三区免费看视频| 亚洲三级在线观看| 亚洲最大色网站| 日韩和欧美一区二区| 日韩精品视频网站| 蜜桃精品在线观看| 国产一区二区三区在线看麻豆| 国产精品资源在线| 成人av资源在线观看| 91首页免费视频| 欧美色爱综合网| 日韩精品专区在线影院观看| 久久久www成人免费无遮挡大片| 国产视频一区在线观看| 综合av第一页| 午夜a成v人精品| 国产一区二区三区在线观看免费视频| 国产福利不卡视频| 色狠狠桃花综合| 日韩一区二区麻豆国产| 亚洲不卡av一区二区三区| 亚洲福中文字幕伊人影院| 美女脱光内衣内裤视频久久网站 | 欧美日韩精品免费观看视频 | 欧美电影免费观看高清完整版| 久久精品一区二区三区av| 国产精品成人一区二区三区夜夜夜 | 亚洲图片欧美视频| 美脚の诱脚舐め脚责91| 成人av在线看| 欧美日韩一区成人| 国产日本欧美一区二区| 亚洲国产精品嫩草影院| 国产麻豆视频一区二区| 欧美在线不卡视频| 久久精品在线观看| 亚洲国产精品一区二区久久| 国产老妇另类xxxxx| 欧美午夜精品免费| 国产欧美日韩亚州综合| 日韩中文欧美在线| av电影在线观看不卡| 欧美成人精品福利| 亚洲一区二区三区视频在线播放| 国产综合久久久久久久久久久久| 色94色欧美sute亚洲线路一久| 精品电影一区二区| 日韩国产精品91| 色婷婷久久99综合精品jk白丝| 2022国产精品视频| 日韩电影在线看| 在线免费一区三区| 国产精品女主播在线观看| 久久精品久久精品| 欧美日韩第一区日日骚| 亚洲欧美成人一区二区三区| 国产69精品久久99不卡| 精品成人一区二区| 麻豆精品国产传媒mv男同| 欧美日韩欧美一区二区| 中文字幕字幕中文在线中不卡视频| 激情综合色播五月| 中文字幕一区二区在线播放| 日韩激情中文字幕| 欧美丝袜第三区| 亚洲女人小视频在线观看| 成人深夜福利app| 久久久九九九九| 国内精品国产成人国产三级粉色 | 粉嫩aⅴ一区二区三区四区五区| 欧美日韩dvd在线观看| 亚洲在线视频网站| 色欧美88888久久久久久影院| 日韩一区欧美一区|