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

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

?? s57writer.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
    poModule->AddField( poFDefn );/* -------------------------------------------------------------------- *//*      Create the FFPC field.                                          *//* -------------------------------------------------------------------- */    poFDefn = new DDFFieldDefn();    poFDefn->Create( "FFPC", "Feature record to feature object pointer control field", "",                     dsc_vector, dtc_mixed_data_type );    poFDefn->AddSubfield( "FFUI", "b11" );    poFDefn->AddSubfield( "FFIX", "b12" );    poFDefn->AddSubfield( "NFPT", "b12" );    poModule->AddField( poFDefn );/* -------------------------------------------------------------------- *//*      Create the FFPT field.                                          *//* -------------------------------------------------------------------- */    poFDefn = new DDFFieldDefn();    poFDefn->Create( "FFPT", "Feature record to feature object pointer field", "*",                     dsc_array, dtc_mixed_data_type );    poFDefn->AddSubfield( "LNAM", "B(64)" );    poFDefn->AddSubfield( "RIND", "b11" );    poFDefn->AddSubfield( "COMT", "A" );    poModule->AddField( poFDefn );/* -------------------------------------------------------------------- *//*      Create the FSPC field.                                          *//* -------------------------------------------------------------------- */    poFDefn = new DDFFieldDefn();    poFDefn->Create( "FSPC", "Feature record to spatial record pointer control field", "",                     dsc_vector, dtc_mixed_data_type );    poFDefn->AddSubfield( "FSUI", "b11" );    poFDefn->AddSubfield( "FSIX", "b12" );    poFDefn->AddSubfield( "NSPT", "b12" );    poModule->AddField( poFDefn );/* -------------------------------------------------------------------- *//*      Create the FSPT field.                                          *//* -------------------------------------------------------------------- */    poFDefn = new DDFFieldDefn();    poFDefn->Create( "FSPT", "Feature record to spatial record pointer field",                      "*", dsc_array, dtc_mixed_data_type );    poFDefn->AddSubfield( "NAME", "B(40)" );    poFDefn->AddSubfield( "ORNT", "b11" );    poFDefn->AddSubfield( "USAG", "b11" );    poFDefn->AddSubfield( "MASK", "b11" );    poModule->AddField( poFDefn );/* -------------------------------------------------------------------- *//*      Create file.                                                    *//* -------------------------------------------------------------------- */    if( !poModule->Create( pszFilename ) )    {        delete poModule;        poModule = NULL;        return FALSE;    }    return TRUE;}/************************************************************************//*                             WriteDSID()                              *//************************************************************************/int S57Writer::WriteDSID( const char *pszDSNM, const char *pszISDT,                           const char *pszSTED, int nAGEN,                           const char *pszCOMT ){/* -------------------------------------------------------------------- *//*      Default values.                                                 *//* -------------------------------------------------------------------- */    if( pszDSNM == NULL )        pszDSNM = "";    if( pszISDT == NULL )        pszISDT = "20030801";    if( pszSTED == NULL )        pszSTED = "03.1";    if( pszCOMT == NULL )        pszCOMT = "";/* -------------------------------------------------------------------- *//*      Add the DSID field.                                             *//* -------------------------------------------------------------------- */    DDFRecord *poRec = MakeRecord();    DDFField *poField;    poField = poRec->AddField( poModule->FindFieldDefn( "DSID" ) );    poRec->SetIntSubfield   ( "DSID", 0, "RCNM", 0, 10 );    poRec->SetIntSubfield   ( "DSID", 0, "RCID", 0, 1 );    poRec->SetIntSubfield   ( "DSID", 0, "EXPP", 0, 1 );    poRec->SetIntSubfield   ( "DSID", 0, "INTU", 0, 4 );    poRec->SetStringSubfield( "DSID", 0, "DSNM", 0, pszDSNM );    poRec->SetStringSubfield( "DSID", 0, "EDTN", 0, "2" );    poRec->SetStringSubfield( "DSID", 0, "UPDN", 0, "0" );    poRec->SetStringSubfield( "DSID", 0, "UADT", 0, pszISDT );    poRec->SetStringSubfield( "DSID", 0, "ISDT", 0, pszISDT );    poRec->SetStringSubfield( "DSID", 0, "STED", 0, pszSTED );    poRec->SetIntSubfield   ( "DSID", 0, "PRSP", 0, 1 );    poRec->SetStringSubfield( "DSID", 0, "PSDN", 0, "" );    poRec->SetStringSubfield( "DSID", 0, "PRED", 0, "2.0" );    poRec->SetIntSubfield   ( "DSID", 0, "PROF", 0, 1 );    poRec->SetIntSubfield   ( "DSID", 0, "AGEN", 0, nAGEN );    poRec->SetStringSubfield( "DSID", 0, "COMT", 0, pszCOMT );/* -------------------------------------------------------------------- *//*      Add the DSSI record.  Eventually we will need to return and     *//*      correct these when we are finished writing.                     *//* -------------------------------------------------------------------- */    poField = poRec->AddField( poModule->FindFieldDefn( "DSSI" ) );    poRec->SetIntSubfield   ( "DSSI", 0, "DSTR", 0, 2 );    poRec->SetIntSubfield   ( "DSSI", 0, "AALL", 0, 1 );    poRec->SetIntSubfield   ( "DSSI", 0, "NALL", 0, 1 );    poRec->SetIntSubfield   ( "DSSI", 0, "NOMR", 0, 0 );    poRec->SetIntSubfield   ( "DSSI", 0, "NOCR", 0, 0 );    poRec->SetIntSubfield   ( "DSSI", 0, "NOGR", 0, 3 );    poRec->SetIntSubfield   ( "DSSI", 0, "NOLR", 0, 0 );    poRec->SetIntSubfield   ( "DSSI", 0, "NOIN", 0, 3 );    poRec->SetIntSubfield   ( "DSSI", 0, "NOCN", 0, 0 );    poRec->SetIntSubfield   ( "DSSI", 0, "NOED", 0, 0 );    poRec->SetIntSubfield   ( "DSSI", 0, "NOFA", 0, 0 );/* -------------------------------------------------------------------- *//*      Write out the record.                                           *//* -------------------------------------------------------------------- */    poRec->Write();    delete poRec;    return TRUE;}/************************************************************************//*                             WriteDSPM()                              *//************************************************************************/int S57Writer::WriteDSPM( int nScale ){    if( nScale == 0 )        nScale = 52000;/* -------------------------------------------------------------------- *//*      Add the DSID field.                                             *//* -------------------------------------------------------------------- */    DDFRecord *poRec = MakeRecord();    DDFField *poField;    poField = poRec->AddField( poModule->FindFieldDefn( "DSPM" ) );    poRec->SetIntSubfield   ( "DSPM", 0, "RCNM", 0, 20 );    poRec->SetIntSubfield   ( "DSPM", 0, "RCID", 0, 1 );    poRec->SetIntSubfield   ( "DSPM", 0, "HDAT", 0, 2 );    poRec->SetIntSubfield   ( "DSPM", 0, "VDAT", 0, 17 );    poRec->SetIntSubfield   ( "DSPM", 0, "SDAT", 0, 23 );    poRec->SetIntSubfield   ( "DSPM", 0, "CSCL", 0, nScale );    poRec->SetIntSubfield   ( "DSPM", 0, "DUNI", 0, 1 );    poRec->SetIntSubfield   ( "DSPM", 0, "HUNI", 0, 1 );    poRec->SetIntSubfield   ( "DSPM", 0, "PUNI", 0, 1 );    poRec->SetIntSubfield   ( "DSPM", 0, "COUN", 0, 1 );    poRec->SetIntSubfield   ( "DSPM", 0, "COMF", 0, nCOMF );    poRec->SetIntSubfield   ( "DSPM", 0, "SOMF", 0, nSOMF );/* -------------------------------------------------------------------- *//*      Write out the record.                                           *//* -------------------------------------------------------------------- */    poRec->Write();    delete poRec;    return TRUE;}/************************************************************************//*                             MakeRecord()                             *//*                                                                      *//*      Create a new empty record, and append a 0001 field with a       *//*      properly set record index in it.                                *//************************************************************************/DDFRecord *S57Writer::MakeRecord(){    DDFRecord *poRec = new DDFRecord( poModule );    DDFField *poField;    unsigned char abyData[3];    abyData[0] = nNext0001Index % 256;    abyData[1] = nNext0001Index / 256;     abyData[2] = DDF_FIELD_TERMINATOR;    poField = poRec->AddField( poModule->FindFieldDefn( "0001" ) );    poRec->SetFieldRaw( poField, 0, (const char *) abyData, 3 );    nNext0001Index++;    return poRec;}/************************************************************************//*                           WriteGeometry()                            *//************************************************************************/int S57Writer::WriteGeometry( DDFRecord *poRec, int nVertCount,                               double *padfX, double *padfY, double *padfZ ){    const char *pszFieldName = "SG2D";    DDFField *poField;    int nRawDataSize, i, nSuccess;    unsigned char *pabyRawData;    if( padfZ != NULL )        pszFieldName = "SG3D";    poField = poRec->AddField( poModule->FindFieldDefn( pszFieldName ) );    if( padfZ )        nRawDataSize = 12 * nVertCount + 1;    else        nRawDataSize = 8 * nVertCount + 1;    pabyRawData = (unsigned char *) CPLMalloc(nRawDataSize);    pabyRawData[nRawDataSize-1] = DDF_UNIT_TERMINATOR;    for( i = 0; i < nVertCount; i++ )    {        GInt32 nXCOO, nYCOO, nVE3D;        nXCOO = CPL_LSBWORD32((GInt32) floor(padfX[i] * nCOMF + 0.5));        nYCOO = CPL_LSBWORD32((GInt32) floor(padfY[i] * nCOMF + 0.5));                if( padfZ == NULL )        {            memcpy( pabyRawData + i * 8, &nYCOO, 4 );            memcpy( pabyRawData + i * 8 + 4, &nXCOO, 4 );        }        else        {            nVE3D = CPL_LSBWORD32((GInt32) floor( padfZ[i] * nSOMF + 0.5 ));            memcpy( pabyRawData + i * 12, &nYCOO, 4 );            memcpy( pabyRawData + i * 12 + 4, &nXCOO, 4 );            memcpy( pabyRawData + i * 12 + 8, &nVE3D, 4 );        }    }    nSuccess = poRec->SetFieldRaw( poField, 0,                                    (const char *) pabyRawData, nRawDataSize );    CPLFree( pabyRawData );    return nSuccess;}/************************************************************************//*                           WritePrimitive()                           *//************************************************************************/int S57Writer::WritePrimitive( OGRFeature *poFeature ){    DDFRecord *poRec = MakeRecord();    DDFField *poField;    OGRGeometry *poGeom = poFeature->GetGeometryRef();/* -------------------------------------------------------------------- *//*      Add the VRID field.                                             *//* -------------------------------------------------------------------- */    poField = poRec->AddField( poModule->FindFieldDefn( "VRID" ) );    poRec->SetIntSubfield   ( "VRID", 0, "RCNM", 0,                               poFeature->GetFieldAsInteger( "RCNM") );    poRec->SetIntSubfield   ( "VRID", 0, "RCID", 0,                               poFeature->GetFieldAsInteger( "RCID") );    poRec->SetIntSubfield   ( "VRID", 0, "RVER", 0, 1 );    poRec->SetIntSubfield   ( "VRID", 0, "RUIN", 0, 1 );/* -------------------------------------------------------------------- *//*      Handle simple point.                                            *//* -------------------------------------------------------------------- */    if( poGeom != NULL && wkbFlatten(poGeom->getGeometryType()) == wkbPoint )    {        double dfX, dfY, dfZ;        OGRPoint *poPoint = (OGRPoint *) poGeom;        CPLAssert( poFeature->GetFieldAsInteger( "RCNM") == RCNM_VI                    || poFeature->GetFieldAsInteger( "RCNM") == RCNM_VC );         dfX = poPoint->getX();        dfY = poPoint->getY();        dfZ = poPoint->getZ();                if( dfZ == 0.0 )            WriteGeometry( poRec, 1, &dfX, &dfY, NULL );        else            WriteGeometry( poRec, 1, &dfX, &dfY, &dfZ );    }/* -------------------------------------------------------------------- *//*      For multipoints we assuming SOUNDG, and write out as SG3D.      *//* -------------------------------------------------------------------- */    else if( poGeom != NULL              && wkbFlatten(poGeom->getGeometryType()) == wkbMultiPoint )    {        OGRMultiPoint *poMP = (OGRMultiPoint *) poGeom;        int i, nVCount = poMP->getNumGeometries();        double *padfX, *padfY, *padfZ;        CPLAssert( poFeature->GetFieldAsInteger( "RCNM") == RCNM_VI                    || poFeature->GetFieldAsInteger( "RCNM") == RCNM_VC );         padfX = (double *) CPLMalloc(sizeof(double) * nVCount);        padfY = (double *) CPLMalloc(sizeof(double) * nVCount);        padfZ = (double *) CPLMalloc(sizeof(double) * nVCount);        for( i = 0; i < nVCount; i++ )        {            OGRPoint *poPoint = (OGRPoint *) poMP->getGeometryRef( i );            padfX[i] = poPoint->getX();            padfY[i] = poPoint->getY();            padfZ[i] = poPoint->getZ();        }        WriteGeometry( poRec, nVCount, padfX, padfY, padfZ );        CPLFree( padfX );        CPLFree( padfY );        CPLFree( padfZ );    }/* -------------------------------------------------------------------- *//*      Handle LINESTRINGs (edge) geometry.                             *//* -------------------------------------------------------------------- */    else if( poGeom != NULL              && wkbFlatten(poGeom->getGeometryType()) == wkbLineString )    {        OGRLineString *poLS = (OGRLineString *) poGeom;        int i, nVCount = poLS->getNumPoints();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产毛片精品视频| 中文字幕一区二区三区四区不卡| 欧美色电影在线| 欧美一区二区三区四区在线观看 | 国产嫩草影院久久久久| 亚洲天堂av一区| 人禽交欧美网站| 99久久99久久精品免费观看| 欧美日韩国产片| 久久久久久久网| 亚洲午夜精品久久久久久久久| 裸体歌舞表演一区二区| 97久久超碰精品国产| 精品免费一区二区三区| 一区二区三区不卡视频 | 久久综合九色综合97婷婷女人| 亚洲欧洲另类国产综合| 伦理电影国产精品| 欧美色图一区二区三区| 国产欧美精品在线观看| 秋霞电影一区二区| 在线观看免费成人| 亚洲国产精品v| 捆绑变态av一区二区三区| 色综合天天在线| 欧美国产综合一区二区| 紧缚奴在线一区二区三区| 欧美视频精品在线观看| 国产精品久久久久久久久免费相片| 香蕉久久夜色精品国产使用方法 | 777a∨成人精品桃花网| 亚洲啪啪综合av一区二区三区| 九九九精品视频| 91精品国产综合久久精品图片| 综合久久国产九一剧情麻豆| 国产jizzjizz一区二区| 欧美videos大乳护士334| 五月婷婷欧美视频| 欧美性受极品xxxx喷水| 亚洲色图视频网站| 一本大道久久精品懂色aⅴ| 国产精品亲子伦对白| 国产成都精品91一区二区三| 精品污污网站免费看| 国产精品久久久久久久久久久免费看| 天天色天天爱天天射综合| 欧美在线免费视屏| 亚洲亚洲精品在线观看| 日本韩国精品一区二区在线观看| 国产精品久久看| 不卡视频一二三| 亚洲图片另类小说| 在线国产电影不卡| 夜夜精品浪潮av一区二区三区| av中文字幕一区| 亚洲日本va午夜在线影院| 99精品一区二区| 亚洲精品第1页| 在线一区二区观看| 日韩精品电影一区亚洲| 日韩欧美一级在线播放| 狠狠狠色丁香婷婷综合激情| 久久久久久久久久久久久夜| 成人激情免费网站| 中文字幕一区在线观看| av在线不卡免费看| 国产欧美日韩另类视频免费观看| www.视频一区| 亚洲最新在线观看| 91精品国产高清一区二区三区| 麻豆精品一区二区| 中文字幕+乱码+中文字幕一区| 99精品久久久久久| 亚洲黄色av一区| 日韩欧美亚洲国产另类 | 免费成人你懂的| 国产视频一区不卡| 色婷婷国产精品| 美女视频一区二区| 国产精品激情偷乱一区二区∴| 欧美午夜在线一二页| 国产麻豆视频一区| 亚洲一区二区在线观看视频| 日韩一区二区三区在线| av激情综合网| 免费在线看成人av| 成人免费一区二区三区视频| 91精品国产综合久久久久久漫画 | 亚洲1区2区3区视频| 久久久午夜精品| 欧美午夜精品久久久| 国产一区二区精品在线观看| 亚洲欧洲精品一区二区精品久久久| 在线观看亚洲一区| 国产成人综合网| 亚洲国产sm捆绑调教视频| 国产日韩精品视频一区| 91精品在线免费观看| av成人老司机| 一区二区高清视频在线观看| 在线播放91灌醉迷j高跟美女| 成人永久免费视频| 日本欧洲一区二区| 亚洲午夜精品网| 中文字幕在线一区免费| 欧美一区在线视频| 欧美在线观看你懂的| 成人中文字幕在线| 激情欧美日韩一区二区| 亚洲午夜激情网页| 亚洲免费在线观看| 国产精品乱码人人做人人爱| 欧美成人激情免费网| 在线观看国产精品网站| 激情久久五月天| 亚洲精品伦理在线| 中文字幕av不卡| 国产午夜亚洲精品羞羞网站| 欧美电影免费提供在线观看| 欧美精三区欧美精三区| 色偷偷成人一区二区三区91| 成人黄色电影在线| 国产精品一区二区果冻传媒| 麻豆精品在线观看| 青青草国产精品97视觉盛宴| 天堂蜜桃91精品| 日韩av网站在线观看| 亚洲高清不卡在线| 偷拍一区二区三区| 日韩一区精品视频| 日韩国产欧美视频| 麻豆精品在线观看| 国内精品不卡在线| 亚洲网友自拍偷拍| 亚洲一区二区黄色| 日韩av中文字幕一区二区三区| 亚洲成av人片在www色猫咪| 亚洲成人你懂的| 热久久国产精品| 国内成人免费视频| 国产成人超碰人人澡人人澡| 成人av网址在线观看| 波多野结衣精品在线| www.av亚洲| 色婷婷av一区二区三区之一色屋| 一本大道久久a久久精品综合| 欧美在线短视频| 538prom精品视频线放| 欧美一区二区三区日韩视频| 日韩欧美国产精品一区| 欧美大片在线观看| 久久久精品综合| 综合色天天鬼久久鬼色| 亚洲一区二区三区四区五区黄 | 欧美一区二区视频观看视频 | 色婷婷国产精品| 制服丝袜成人动漫| 久久免费电影网| 亚洲女同女同女同女同女同69| 欧美激情在线观看视频免费| 亚洲婷婷综合色高清在线| 天天影视色香欲综合网老头| 国产一区二区美女| 91在线你懂得| 日韩欧美国产一二三区| 亚洲精品中文字幕在线观看| 亚洲一区二区三区在线看| 亚洲国产精品久久久久秋霞影院| 久久er99精品| 欧美这里有精品| 中国色在线观看另类| 亚洲国产精品一区二区www| 国产伦精品一区二区三区免费 | 国产精品白丝jk黑袜喷水| 91国在线观看| 久久久久久久久蜜桃| 亚洲综合在线五月| 精品少妇一区二区三区日产乱码 | 91免费视频网址| 亚洲精品一区二区三区在线观看 | 日韩一区二区三区观看| 亚洲精品videosex极品| 成人精品电影在线观看| 久久亚洲私人国产精品va媚药| 亚洲成人午夜电影| 在线观看日韩电影| 亚洲图片另类小说| 99麻豆久久久国产精品免费| 久久色在线视频| 蜜桃精品视频在线| 日韩一区二区免费高清| 午夜欧美在线一二页| 色狠狠av一区二区三区| 亚洲人成7777| 色婷婷综合激情| 一区二区高清视频在线观看| 91久久精品一区二区二区| 亚洲精品高清在线观看| 在线影院国内精品| 亚洲第一福利一区|