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

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

?? shptree.c

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*                         SHPTreeSplitBounds()                         *//*                                                                      *//*      Split a region into two subregion evenly, cutting along the     *//*      longest dimension.                                              *//************************************************************************/void SHPAPI_CALLSHPTreeSplitBounds( double *padfBoundsMinIn, double *padfBoundsMaxIn,                    double *padfBoundsMin1, double * padfBoundsMax1,                    double *padfBoundsMin2, double * padfBoundsMax2 ){/* -------------------------------------------------------------------- *//*      The output bounds will be very similar to the input bounds,     *//*      so just copy over to start.                                     *//* -------------------------------------------------------------------- */    memcpy( padfBoundsMin1, padfBoundsMinIn, sizeof(double) * 4 );    memcpy( padfBoundsMax1, padfBoundsMaxIn, sizeof(double) * 4 );    memcpy( padfBoundsMin2, padfBoundsMinIn, sizeof(double) * 4 );    memcpy( padfBoundsMax2, padfBoundsMaxIn, sizeof(double) * 4 );    /* -------------------------------------------------------------------- *//*      Split in X direction.                                           *//* -------------------------------------------------------------------- */    if( (padfBoundsMaxIn[0] - padfBoundsMinIn[0])        			> (padfBoundsMaxIn[1] - padfBoundsMinIn[1]) )    {        double	dfRange = padfBoundsMaxIn[0] - padfBoundsMinIn[0];        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 = (int *)         SfRealloc( psTreeNode->panShapeIds,                   sizeof(int) * psTreeNode->nShapeCount );    psTreeNode->panShapeIds[psTreeNode->nShapeCount-1] = psObject->nShapeId;    if( psTreeNode->papsShapeObj != NULL )    {        psTreeNode->papsShapeObj = (SHPObject **)            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 ){    psTree->nTotalCount++;    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.                              *//************************************************************************//* helper for qsort */static intcompare_ints( const void * a, const void * b){    return (*(int*)a) - (*(int*)b);}int SHPAPI_CALL1(*)SHPTreeFindLikelyShapes( SHPTree * hTree,                         double * padfBoundsMin, double * padfBoundsMax,                         int * pnShapeCount ){    int	*panShapeList=NULL, nMaxShapes = 0;/* -------------------------------------------------------------------- *//*      Perform the search by recursive descent.                        *//* -------------------------------------------------------------------- */    *pnShapeCount = 0;    SHPTreeCollectShapeIds( hTree, hTree->psRoot,                            padfBoundsMin, padfBoundsMax,                            pnShapeCount, &nMaxShapes,                            &panShapeList );/* -------------------------------------------------------------------- *//*      Sort the id array                                               *//* -------------------------------------------------------------------- */    qsort(panShapeList, *pnShapeCount, sizeof(int), compare_ints);    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] ) )

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人激情文学综合网| 午夜欧美视频在线观看| 欧美三级韩国三级日本三斤| 久久er精品视频| 亚洲欧洲色图综合| 日韩欧美高清一区| 欧美在线999| 成人网男人的天堂| 国产一区啦啦啦在线观看| 亚洲国产精品精华液2区45| 欧美一级久久久| 欧美日韩一区高清| 91同城在线观看| 91在线国产观看| 国产成人鲁色资源国产91色综| 婷婷丁香激情综合| 国产精品毛片高清在线完整版| 在线看国产一区二区| 不卡av在线免费观看| 成人免费视频一区| 国产一区二区三区四区五区美女| 亚洲小少妇裸体bbw| 1区2区3区国产精品| 精品久久国产97色综合| 日韩视频在线永久播放| 欧美videos大乳护士334| 久久亚洲一区二区三区四区| 日韩欧美电影在线| 国产精品久久福利| 丝瓜av网站精品一区二区 | 一区二区三区欧美久久| 毛片一区二区三区| 香蕉成人啪国产精品视频综合网| 日韩精品色哟哟| 蜜臀久久久久久久| a美女胸又www黄视频久久| 欧美一区二区三区精品| 亚洲手机成人高清视频| 日本va欧美va欧美va精品| 成人18精品视频| 欧美一二三四区在线| 最新日韩av在线| 久久精品国产精品亚洲精品| 91视频.com| 国产色婷婷亚洲99精品小说| 亚洲一区二区中文在线| 粉嫩在线一区二区三区视频| 精品少妇一区二区| 日韩和欧美一区二区三区| 99久久精品国产精品久久| 精品久久久久久综合日本欧美| 亚洲免费在线视频| av在线不卡电影| 国产精品萝li| 99久久精品免费观看| 中文字幕久久午夜不卡| 激情五月激情综合网| 欧美人与性动xxxx| 天堂影院一区二区| 91麻豆精品国产91久久久久久| 午夜久久久久久| 日韩免费一区二区| 国产在线精品免费| 久久久亚洲精品一区二区三区 | 极品少妇xxxx精品少妇偷拍| 欧美日产国产精品| 日韩av网站在线观看| 91麻豆精品国产91久久久久久| 日韩精品一级中文字幕精品视频免费观看 | 经典三级一区二区| 国产日韩一级二级三级| 福利视频网站一区二区三区| 国产精品毛片久久久久久久| 国产精品乱人伦| 成人av电影在线网| 亚洲免费在线观看视频| 欧美三级视频在线观看| 三级一区在线视频先锋| 欧美xxxxx牲另类人与| 夫妻av一区二区| 亚洲国产一二三| 精品区一区二区| jvid福利写真一区二区三区| 亚洲最大色网站| 精品久久一二三区| 99国产精品久久久久| 亚洲综合在线免费观看| 精品国产青草久久久久福利| av电影在线观看一区| 午夜一区二区三区视频| 久久亚区不卡日本| 7777女厕盗摄久久久| 成人午夜电影网站| 丝袜诱惑制服诱惑色一区在线观看| 26uuu色噜噜精品一区二区| 日本道色综合久久| 国产成人综合在线观看| 日本亚洲最大的色成网站www| 国产精品国产三级国产三级人妇| 欧美日本国产视频| 在线视频国内自拍亚洲视频| 国产suv精品一区二区883| 人人超碰91尤物精品国产| 亚洲人精品午夜| 国产精品午夜久久| 欧美精品一区在线观看| 欧美一区在线视频| 欧美亚日韩国产aⅴ精品中极品| 国产不卡免费视频| 国产麻豆视频精品| 麻豆中文一区二区| 日韩国产一二三区| 亚洲自拍另类综合| 亚洲综合精品自拍| 亚洲大片免费看| 伊人开心综合网| 一区二区三区丝袜| 亚洲你懂的在线视频| 亚洲精品高清在线观看| 亚洲精品第一国产综合野| 一区二区三区欧美| 午夜精品福利视频网站| 奇米四色…亚洲| 国产激情一区二区三区桃花岛亚洲 | 一区二区免费视频| 亚洲一区在线观看免费| 琪琪一区二区三区| 国产成人综合视频| 色婷婷综合久久久久中文一区二区| 91久久国产最好的精华液| 6080午夜不卡| 国产精品视频在线看| 一区二区三区日韩欧美| 日本亚洲三级在线| 精品中文av资源站在线观看| 成人动漫av在线| 欧美色图一区二区三区| 日韩欧美一区二区不卡| 中文字幕在线观看一区| 日韩影视精彩在线| 顶级嫩模精品视频在线看| 欧美亚洲综合在线| 国产日韩欧美综合一区| 亚洲福中文字幕伊人影院| 国产原创一区二区三区| 欧美亚洲日本国产| 日本一二三不卡| 裸体一区二区三区| 91福利视频网站| 亚洲欧洲色图综合| 国产乱码精品一品二品| 欧美一区在线视频| 亚洲国产欧美日韩另类综合| 懂色av一区二区三区蜜臀| 欧美一区中文字幕| 亚洲国产精品久久艾草纯爱| 99久久伊人精品| 欧美韩国日本综合| 激情久久五月天| 欧美sm极限捆绑bd| 奇米色一区二区| 欧美一级xxx| 久久精品72免费观看| 欧美一区二区视频网站| 午夜a成v人精品| 91精品国产欧美一区二区18 | 激情成人综合网| 精品国产一区二区三区久久久蜜月 | 国产精品午夜久久| 成人三级在线视频| 中文字幕日韩av资源站| 99精品一区二区| 亚洲乱码日产精品bd| 欧洲色大大久久| 肉肉av福利一精品导航| 欧美一区二区三区色| 国内精品伊人久久久久av影院| 久久久久国产免费免费| 不卡影院免费观看| 一二三四社区欧美黄| 日韩午夜激情电影| 国产成人一区二区精品非洲| 一区二区视频在线看| 日韩亚洲国产中文字幕欧美| 国产精品一区二区无线| 亚洲精品欧美二区三区中文字幕| 欧洲精品一区二区| 国产激情视频一区二区在线观看| 2023国产精品视频| 色婷婷激情一区二区三区| 青青草视频一区| 国产精品色在线观看| 欧美日韩一卡二卡三卡| 岛国精品在线播放| 日韩精品一二区| 艳妇臀荡乳欲伦亚洲一区| 久久久久久久综合日本| 欧美三级电影精品| 色呦呦网站一区| 成人免费视频app|