提交 3787f4fa28acb73c34127dd1e7832047990d408d
Merge branch 'master' of http://gitlab.ctune.cn/DMapServer/DMapServer4.1
正在显示
13 个修改的文件
包含
99 行增加
和
198 行删除
... | ... | @@ -14,6 +14,7 @@ SET (TILESERVER_SRCS |
14 | 14 | # dmpwmtsservice.cpp |
15 | 15 | wmts/dmpwmtsutils.cpp |
16 | 16 | tms/dmptms.cpp |
17 | + tms/dmptmstileprovider.cpp | |
17 | 18 | ) |
18 | 19 | |
19 | 20 | SET (TILESERVER_HDRS |
... | ... | @@ -30,6 +31,7 @@ SET (TILESERVER_HDRS |
30 | 31 | # dmpwmtsservice.h |
31 | 32 | wmts/dmpwmtsutils.h |
32 | 33 | tms/dmptms.h |
34 | + tms/dmptmstileprovider.h | |
33 | 35 | ) |
34 | 36 | ######################################################## |
35 | 37 | # Build | ... | ... |
... | ... | @@ -6,10 +6,16 @@ |
6 | 6 | * Email: zhongpingw@chinadci.com |
7 | 7 | * copyright: 广州城市信息研究所有限公司 |
8 | 8 | ***************************************************************************/ |
9 | +#include <map> | |
9 | 10 | #include "dmptms.h" |
10 | 11 | #include "dmptilelayer.h" |
12 | +#include "dmpserverrequest.h" | |
13 | +#include "dmpserverresponse.h" | |
11 | 14 | #include "dmpservercontext.h" |
12 | 15 | #include "dmplogger.h" |
16 | +#include "dmptilelayer.h" | |
17 | +#include "dmpproject.h" | |
18 | +#include "dmptmstileprovider.h" | |
13 | 19 | |
14 | 20 | namespace DmpTms |
15 | 21 | { |
... | ... | @@ -26,5 +32,54 @@ namespace DmpTms |
26 | 32 | |
27 | 33 | void DmpTMSService::executeRequest(const DmpServerContext &context) |
28 | 34 | { |
35 | + | |
36 | + if(context.request()->isRestful()) | |
37 | + { | |
38 | + std::string path_=context.request()->path(); | |
39 | + std::vector<std::string> vec_; | |
40 | + boost::split(vec_,context.request()->path(),boost::is_any_of("/"),boost::token_compress_on); | |
41 | + int isize_=vec_.size(); | |
42 | + if(isize_<4) | |
43 | + { | |
44 | + context.response()->write("Tms,Operation is null"); | |
45 | + return; | |
46 | + } | |
47 | + std::string::size_type idx0_,idx1_; | |
48 | + idx0_=vec_[isize_-1].find("png"); | |
49 | + idx1_=vec_[isize_-1].find("jpg"); | |
50 | + | |
51 | + if((idx0_!=std::string::npos)||(idx1_!=std::string::npos)) | |
52 | + { | |
53 | + std::vector<std::string> vec0_; | |
54 | + boost::split(vec0_,vec_[isize_-1],boost::is_any_of("."),boost::token_compress_on); | |
55 | + int tileCol_=atoi(vec0_[0].c_str()); | |
56 | + int tileRow_=atoi(vec_[isize_-2].c_str()); | |
57 | + int tileMatrix_=atoi(vec_[isize_-3].c_str()); | |
58 | + const DmpProject *project = context.project(); | |
59 | + DmpTileLayer *tileLayer = static_cast<DmpTileLayer *>(project->getLayer("layer")); | |
60 | + std::string format_=vec0_[1].c_str(); | |
61 | + std::string filePath_=tileLayer->getDataSource(); | |
62 | + if(filePath_.empty()) | |
63 | + { | |
64 | + context.response()->write("Tms,Operation is null"); | |
65 | + } | |
66 | + else | |
67 | + { | |
68 | + DmpTmsTileProvider provider_=DmpTmsTileProvider(filePath_); | |
69 | + provider_.WriteTile(tileRow_, tileCol_, tileMatrix_, format_, *context.response()); | |
70 | + } | |
71 | + } | |
72 | + else | |
73 | + { | |
74 | + context.response()->write("Tms,Operation is null"); | |
75 | + return; | |
76 | + } | |
77 | + } | |
78 | + else | |
79 | + { | |
80 | + context.response()->write("非TMS请求"); | |
81 | + } | |
82 | + | |
29 | 83 | } |
84 | + | |
30 | 85 | } // namespace DmpTms |
\ No newline at end of file | ... | ... |
1 | -/************************************************************************** | |
2 | -* file: dmpserverparameters.cpp | |
3 | - | |
4 | -* Author: lijiahuan | |
5 | -* Date: 2021-12-09 17:41:00 | |
6 | -* Email: jiahuanl@chinadci.com | |
7 | -* copyright: 广州城市信息研究所有限公司 | |
8 | -***************************************************************************/ | |
9 | -#include <iostream> | |
10 | -#include <boost/lexical_cast.hpp> | |
11 | -#include <boost/algorithm/string.hpp> | |
12 | -#include "dmplogger.h" | |
13 | -#include "dmpserverutils.h" | |
14 | -#include "dmptmsparameters.h" | |
15 | - | |
16 | - | |
17 | -namespace DmpTms | |
18 | -{ | |
19 | - DmpTmsParameters::DmpTmsParameters(const DmpServerParameters ¶meters) | |
20 | - { | |
21 | - params_ = parameters.Parameters(); | |
22 | - } | |
23 | - DmpTmsParameters::DmpTmsParameters() : DmpServerParameters() | |
24 | - { | |
25 | - | |
26 | - } | |
27 | - int DmpTmsParameters::TileMatrix() const | |
28 | - { | |
29 | - std::map<std::string, std::string>::const_iterator iter; | |
30 | - iter = params_.find("TILEMATRIX"); | |
31 | - if (iter != params_.end()) | |
32 | - { | |
33 | - try | |
34 | - { | |
35 | - int num_tile_atrix = boost::lexical_cast<int>(iter->second); | |
36 | - return num_tile_atrix; | |
37 | - } | |
38 | - catch (boost::bad_lexical_cast &e) | |
39 | - { | |
40 | - LOGGER_ERROR(e.what()); | |
41 | - } | |
42 | - } | |
43 | - return -1; | |
44 | - } | |
45 | - int DmpTmsParameters::TileRow() const | |
46 | - { | |
47 | - std::map<std::string, std::string>::const_iterator iter; | |
48 | - iter = params_.find("TILEROW"); | |
49 | - if (iter != params_.end()) | |
50 | - { | |
51 | - try | |
52 | - { | |
53 | - int num_tile_row = boost::lexical_cast<int>(iter->second); | |
54 | - return num_tile_row; | |
55 | - } | |
56 | - catch (boost::bad_lexical_cast &e) | |
57 | - { | |
58 | - LOGGER_ERROR(e.what()); | |
59 | - } | |
60 | - } | |
61 | - return -1; | |
62 | - } | |
63 | - int DmpTmsParameters::TileCol() const | |
64 | - { | |
65 | - std::map<std::string, std::string>::const_iterator iter; | |
66 | - iter = params_.find("TILECOL"); | |
67 | - if (iter != params_.end()) | |
68 | - { | |
69 | - try | |
70 | - { | |
71 | - int num_tile_col = boost::lexical_cast<int>(iter->second); | |
72 | - return num_tile_col; | |
73 | - } | |
74 | - catch (boost::bad_lexical_cast &e) | |
75 | - { | |
76 | - LOGGER_ERROR(e.what()); | |
77 | - } | |
78 | - } | |
79 | - return -1; | |
80 | - } | |
81 | - | |
82 | - std::string DmpTmsParameters::TileMatrixSet() const | |
83 | - { | |
84 | - std::string tile_matrix_set; | |
85 | - std::map<std::string, std::string>::const_iterator iter; | |
86 | - iter = params_.find("TILEMATRIXSET"); | |
87 | - if (iter != params_.end()) | |
88 | - { | |
89 | - tile_matrix_set = iter->second; | |
90 | - } | |
91 | - return tile_matrix_set; | |
92 | - } | |
93 | - std::string DmpTmsParameters::Layer() const | |
94 | - { | |
95 | - std::string layer; | |
96 | - std::map<std::string, std::string>::const_iterator iter; | |
97 | - iter = params_.find("LAYER"); | |
98 | - if (iter != params_.end()) | |
99 | - { | |
100 | - layer = iter->second; | |
101 | - } | |
102 | - return layer; | |
103 | - } | |
104 | - | |
105 | - DmpTmsParameters::Format DmpTmsParameters::ImageFormat() const | |
106 | - { | |
107 | - std::string frm; | |
108 | - std::map<std::string, std::string>::const_iterator iter; | |
109 | - iter = params_.find("format"); | |
110 | - if (iter != params_.end()) | |
111 | - { | |
112 | - frm = iter->second; | |
113 | - if (frm.empty()) { | |
114 | - return Format::NONE; | |
115 | - } | |
116 | - Format f = Format::PNG; | |
117 | - boost::to_lower(frm); | |
118 | - if (frm.compare("jpg") == 0 || frm.compare("jpeg") == 0 || frm.compare("image/jpeg") == 0 ) { | |
119 | - f = Format::JPG; | |
120 | - } | |
121 | - return f; | |
122 | - } | |
123 | - return Format::NONE; | |
124 | - } | |
125 | -} | |
\ No newline at end of file |
1 | -/************************************************************************** | |
2 | -* file: dmpserverparameters.h | |
3 | - | |
4 | -* Author: lijiahuan | |
5 | -* Date: 2021-12-09 17:41:00 | |
6 | -* Email: jiahuanl@chinadci.com | |
7 | -* copyright: 广州城市信息研究所有限公司 | |
8 | -***************************************************************************/ | |
9 | -#ifndef __dmptmsparameters_h__ | |
10 | -#define __dmptmsparameters_h__ | |
11 | - | |
12 | -#include "dmpserverparameters.h" | |
13 | -namespace DmpTms | |
14 | -{ | |
15 | - class DmpTmsParameters : public DmpServerParameters | |
16 | - { | |
17 | - public: | |
18 | - enum class Format | |
19 | - { | |
20 | - NONE, | |
21 | - JPG, | |
22 | - PNG | |
23 | - }; | |
24 | - DmpTmsParameters(const DmpServerParameters ¶meters); | |
25 | - DmpTmsParameters(); | |
26 | - virtual ~DmpTmsParameters() = default; | |
27 | - std::string Layer() const; | |
28 | - Format ImageFormat() const; | |
29 | - std::string TileMatrixSet() const; | |
30 | - int TileMatrix() const; | |
31 | - int TileRow() const; | |
32 | - int TileCol() const; | |
33 | - }; | |
34 | -} | |
35 | -#endif //__dmptmsparameters_h__ | |
\ No newline at end of file |
... | ... | @@ -19,8 +19,7 @@ namespace DmpTms |
19 | 19 | std::string tile_path = file_rootPath+"/"+std::to_string(level)+"/"+std::to_string(row)+"/"+std::to_string(col)+"."+format; |
20 | 20 | std::ifstream fread(tile_path, std::ifstream::binary); |
21 | 21 | if(!fread) |
22 | - { | |
23 | - | |
22 | + { | |
24 | 23 | response.sendError(500, "找不到瓦片:("); |
25 | 24 | return; |
26 | 25 | } | ... | ... |
... | ... | @@ -16,11 +16,13 @@ namespace DmpTms |
16 | 16 | { |
17 | 17 | class DmpTmsTileProvider |
18 | 18 | { |
19 | - public: | |
19 | + public: | |
20 | + std::string ImageFormat() const; | |
20 | 21 | DmpTmsTileProvider(const std::string& root_path); |
21 | 22 | void WriteTile(const int row, const int col, const int level, const std::string& format, DmpServerResponse& response) ; |
22 | - protected: | |
23 | + protected: | |
23 | 24 | std::string file_rootPath; |
24 | 25 | }; |
25 | 26 | } |
27 | + | |
26 | 28 | #endif |
\ No newline at end of file | ... | ... |
... | ... | @@ -31,7 +31,7 @@ namespace DmpWmts |
31 | 31 | } |
32 | 32 | } |
33 | 33 | l = "L" + l; |
34 | - string r = IntToHexStr(rGroup); | |
34 | + string r = DmpWmtsUtils::IntToHexStr(rGroup); | |
35 | 35 | |
36 | 36 | int rLength = r.length(); |
37 | 37 | if (rLength < 4) |
... | ... | @@ -43,7 +43,7 @@ namespace DmpWmts |
43 | 43 | } |
44 | 44 | r = "R" + r; |
45 | 45 | |
46 | - string c = IntToHexStr(cGroup); | |
46 | + string c = DmpWmtsUtils::IntToHexStr(cGroup); | |
47 | 47 | int cLength = c.length(); |
48 | 48 | if (cLength < 4) |
49 | 49 | { | ... | ... |
... | ... | @@ -28,7 +28,7 @@ namespace DmpWmts |
28 | 28 | } |
29 | 29 | void DmpEsriTileProvider::WriteTile(const int row, const int col, const int level, const std::string& format, DmpServerResponse& response) |
30 | 30 | { |
31 | - std::string level_str = "L" + IntToFormatStr(level); | |
31 | + std::string level_str = "L" + DmpWmtsUtils::IntToFormatStr(level); | |
32 | 32 | std::string row_str = "R" + IntToHex8Str(row); |
33 | 33 | std::string col_str = "C" + IntToHex8Str(col); |
34 | 34 | ... | ... |
... | ... | @@ -58,7 +58,27 @@ namespace DmpWmts |
58 | 58 | |
59 | 59 | return provider; |
60 | 60 | } |
61 | - | |
61 | + int TileProviderFactory::StringToVector(std::string& strVector) | |
62 | + { | |
63 | + int iVector_=-1; | |
64 | + if(std::strcmp(strVector.c_str(),"ESRI_V0")==0) | |
65 | + { | |
66 | + iVector_=0; | |
67 | + } | |
68 | + else if(std::strcmp(strVector.c_str(),"ESRI_V1")==0) | |
69 | + { | |
70 | + iVector_=1; | |
71 | + } | |
72 | + else if(std::strcmp(strVector.c_str(),"ESRI_V2")==0) | |
73 | + { | |
74 | + iVector_=2; | |
75 | + } | |
76 | + else | |
77 | + { | |
78 | + iVector_=3; | |
79 | + } | |
80 | + return iVector_; | |
81 | + } | |
62 | 82 | // CapabiliTileProviderFactory::CapabiliTileProviderFactory() |
63 | 83 | // { |
64 | 84 | // } | ... | ... |
... | ... | @@ -31,7 +31,8 @@ namespace DmpWmts |
31 | 31 | class TileProviderFactory |
32 | 32 | { |
33 | 33 | public: |
34 | - static std::shared_ptr<DmpTileProvider> GetProvider( DmpTileLayer* dmpTileLayer); | |
34 | + static std::shared_ptr<DmpTileProvider> GetProvider( DmpTileLayer* dmpTileLayer); | |
35 | + static int StringToVector(std::string& strVector); | |
35 | 36 | private: |
36 | 37 | TileProviderFactory(); |
37 | 38 | }; | ... | ... |
... | ... | @@ -11,9 +11,8 @@ |
11 | 11 | #include <boost/property_tree/xml_parser.hpp> |
12 | 12 | #include <string> |
13 | 13 | namespace DmpWmts |
14 | -{ | |
15 | - | |
16 | - std::string IntToFormatStr(const int num) | |
14 | +{ | |
15 | + std::string DmpWmtsUtils::IntToFormatStr(const int num) | |
17 | 16 | { |
18 | 17 | std::string str = std::to_string(num); |
19 | 18 | if(num>=0 && num<10) |
... | ... | @@ -23,7 +22,7 @@ namespace DmpWmts |
23 | 22 | return str; |
24 | 23 | } |
25 | 24 | |
26 | - std::string IntToHexStr(const int num) | |
25 | + std::string DmpWmtsUtils::IntToHexStr(const int num) | |
27 | 26 | { |
28 | 27 | char* buffer = new char[8]; |
29 | 28 | sprintf(buffer,"%x",num); |
... | ... | @@ -31,26 +30,5 @@ namespace DmpWmts |
31 | 30 | delete[] buffer; |
32 | 31 | return str; |
33 | 32 | } |
34 | - int StringToVector(std::string& strVector) | |
35 | - { | |
36 | - int iVector_=-1; | |
37 | - if(std::strcmp(strVector.c_str(),"ESRI_V0")==0) | |
38 | - { | |
39 | - iVector_=0; | |
40 | - } | |
41 | - else if(std::strcmp(strVector.c_str(),"ESRI_V1")==0) | |
42 | - { | |
43 | - iVector_=1; | |
44 | - } | |
45 | - else if(std::strcmp(strVector.c_str(),"ESRI_V2")==0) | |
46 | - { | |
47 | - iVector_=2; | |
48 | - } | |
49 | - else | |
50 | - { | |
51 | - iVector_=3; | |
52 | - } | |
53 | - return iVector_; | |
54 | - } | |
55 | 33 | |
56 | 34 | } | ... | ... |
... | ... | @@ -15,9 +15,13 @@ |
15 | 15 | |
16 | 16 | namespace DmpWmts |
17 | 17 | { |
18 | - std::string IntToFormatStr(const int num); | |
19 | - std::string IntToHexStr(const int num); | |
20 | - int StringToVector(std::string& strVector); | |
18 | + class DmpWmtsUtils | |
19 | + { | |
20 | + public: | |
21 | + static std::string IntToFormatStr(const int num); | |
22 | + static std::string IntToHexStr(const int num); | |
23 | + | |
24 | + }; | |
21 | 25 | } |
22 | 26 | |
23 | 27 | #endif //__dmpwmtsutils_h__ | ... | ... |
请
注册
或
登录
后发表评论