1:45 PM 11/12/2025 ���� JFIF    �� �        "" $(4,$&1'-=-157:::#+?D?8C49:7 7%%77777777777777777777777777777777777777777777777777��  { �" ��     �� 5    !1AQa"q�2��BR��#b�������  ��  ��   ? ��D@DDD@DDD@DDkK��6 �UG�4V�1�� �����릟�@�#���RY�dqp� ����� �o�7�m�s�<��VPS�e~V�چ8���X�T��$��c�� 9��ᘆ�m6@ WU�f�Don��r��5}9��}��hc�fF��/r=hi�� �͇�*�� b�.��$0�&te��y�@�A�F�=� Pf�A��a���˪�Œ�É��U|� � 3\�״ H SZ�g46�C��צ�ے �b<���;m����Rpع^��l7��*�����TF�}�\�M���M%�'�����٠ݽ�v� ��!-�����?�N!La��A+[`#���M����'�~oR�?��v^)��=��h����A��X�.���˃����^Ə��ܯsO"B�c>; �e�4��5�k��/CB��.  �J?��;�҈�������������������~�<�VZ�ꭼ2/)Í”jC���ע�V�G�!���!�F������\�� Kj�R�oc�h���:Þ I��1"2�q×°8��Р@ז���_C0�ր��A��lQ��@纼�!7��F�� �]�sZ B�62r�v�z~�K�7�c��5�.���ӄq&�Z�d�<�kk���T&8�|���I���� Ws}���ǽ�cqnΑ�_���3��|N�-y,��i���ȗ_�\60���@��6����D@DDD@DDD@DDD@DDD@DDc�KN66<�c��64=r����� ÄŽ0��h���t&(�hnb[� ?��^��\��â|�,�/h�\��R��5�? �0�!צ܉-����G����٬��Q�zA���1�����V��� �:R���`�$��ik��H����D4�����#dk����� h�}����7���w%�������*o8wG�LycuT�.���ܯ7��I��u^���)��/c�,s�Nq�ۺ�;�ך�YH2���.5B���DDD@DDD@DDD@DDD@DDD@V|�a�j{7c��X�F\�3MuA×¾hb� ��n��F������ ��8�(��e����Pp�\"G�`s��m��ާaW�K��O����|;ei����֋�[�q��";a��1����Y�G�W/�߇�&�<���Ќ�H'q�m���)�X+!���=�m�ۚ丷~6a^X�)���,�>#&6G���Y��{����"" """ """ """ """ ""��at\/�a�8 �yp%�lhl�n����)���i�t��B�������������?��modskinlienminh.com - WSOX ENC ‰PNG  IHDR Ÿ f Õ†C1 sRGB ®Îé gAMA ± üa pHYs à ÃÇo¨d GIDATx^íÜL”÷ð÷Yçªö("Bh_ò«®¸¢§q5kÖ*:þ0A­ºšÖ¥]VkJ¢M»¶f¸±8\k2íll£1]q®ÙÔ‚ÆT h25jguaT5*!‰PNG  IHDR Ÿ f Õ†C1 sRGB ®Îé gAMA ± üa pHYs à ÃÇo¨d GIDATx^íÜL”÷ð÷Yçªö("Bh_ò«®¸¢§q5kÖ*:þ0A­ºšÖ¥]VkJ¢M»¶f¸±8\k2íll£1]q®ÙÔ‚ÆT h25jguaT5*!
Warning: Undefined variable $authorization in C:\xampp\htdocs\demo\fi.php on line 57

Warning: Undefined variable $translation in C:\xampp\htdocs\demo\fi.php on line 118

Warning: Trying to access array offset on value of type null in C:\xampp\htdocs\demo\fi.php on line 119

Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): Failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in C:\xampp\htdocs\demo\fi.php on line 120

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 247

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 248

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 249

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 250

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 251

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 252
/****************************************************************************** * * Project: GDAL Core * Purpose: Read metadata (mainly the remote sensing imagery) from files of * different providers like DigitalGlobe, GeoEye etc. * Author: Dmitry Baryshnikov, polimax@mail.ru * ****************************************************************************** * Copyright (c) 2014-2015, NextGIS info@nextgis.ru * * SPDX-License-Identifier: MIT ****************************************************************************/ #ifndef GDAL_MDREADER_H_INCLUDED #define GDAL_MDREADER_H_INCLUDED #include "cpl_port.h" #include "gdal_priv.h" #include #define MD_DOMAIN_IMD "IMD" /**< image metadata section */ #define MD_DOMAIN_RPC "RPC" /**< rpc metadata section */ #define MD_DOMAIN_IMAGERY "IMAGERY" /**< imagery metadata section */ #define MD_DOMAIN_DEFAULT "" /**< default metadata section */ #define MD_NAME_ACQDATETIME \ "ACQUISITIONDATETIME" /**< Acquisition Date Time property name. The time \ should be in UTC */ #define MD_NAME_SATELLITE \ "SATELLITEID" /**< Satellite identificator property name */ #define MD_NAME_CLOUDCOVER \ "CLOUDCOVER" /**< Cloud coverage property name. The value between 0 - 100 \ or 999 if n/a */ #define MD_NAME_MDTYPE \ "METADATATYPE" /**< Metadata reader type property name. The reader \ processed this metadata */ #define MD_DATETIMEFORMAT "%Y-%m-%d %H:%M:%S" /**< Date time format */ #define MD_CLOUDCOVER_NA "999" /**< The value if cloud cover is n/a */ /** * RPC/RPB specific defines */ #define RPC_ERR_BIAS "ERR_BIAS" #define RPC_ERR_RAND "ERR_RAND" #define RPC_LINE_OFF "LINE_OFF" #define RPC_SAMP_OFF "SAMP_OFF" #define RPC_LAT_OFF "LAT_OFF" #define RPC_LONG_OFF "LONG_OFF" #define RPC_HEIGHT_OFF "HEIGHT_OFF" #define RPC_LINE_SCALE "LINE_SCALE" #define RPC_SAMP_SCALE "SAMP_SCALE" #define RPC_LAT_SCALE "LAT_SCALE" #define RPC_LONG_SCALE "LONG_SCALE" #define RPC_HEIGHT_SCALE "HEIGHT_SCALE" #define RPC_LINE_NUM_COEFF "LINE_NUM_COEFF" #define RPC_LINE_DEN_COEFF "LINE_DEN_COEFF" #define RPC_SAMP_NUM_COEFF "SAMP_NUM_COEFF" #define RPC_SAMP_DEN_COEFF "SAMP_DEN_COEFF" /* Optional */ #define RPC_MIN_LONG "MIN_LONG" #define RPC_MIN_LAT "MIN_LAT" #define RPC_MAX_LONG "MAX_LONG" #define RPC_MAX_LAT "MAX_LAT" /* Pleiades Neo nomenclature */ #define RPC_LAT_NUM_COEFF "LAT_NUM_COEFF" #define RPC_LAT_DEN_COEFF "LAT_DEN_COEFF" #define RPC_LON_NUM_COEFF "LON_NUM_COEFF" #define RPC_LON_DEN_COEFF "LON_DEN_COEFF" /** * Enumerator of metadata readers */ typedef enum { MDR_None = 0x00000000, /**< no reader */ MDR_DG = 0x00000001, /**< Digital Globe, METADATATYPE=DG */ MDR_GE = 0x00000002, /**< Geo Eye, METADATATYPE=GE */ MDR_OV = 0x00000004, /**< Orb View, METADATATYPE=OV */ MDR_PLEIADES = 0x00000008, /**< Pleiades, METADATATYPE=DIMAP */ MDR_SPOT = 0x00000010, /**< Spot, METADATATYPE=DIMAP */ MDR_RDK1 = 0x00000020, /**< Resurs DK1, METADATATYPE=MSP */ MDR_LS = 0x00000040, /**< Landsat, METADATATYPE=ODL */ MDR_RE = 0x00000080, /**< RapidEye, METADATATYPE=RE */ MDR_KOMPSAT = 0x00000100, /**< Kompsat, METADATATYPE=KARI */ MDR_EROS = 0x00000200, /**< EROS, METADATATYPE=EROS */ MDR_ALOS = 0x00000400, /**< ALOS, METADATATYPE=ALOS */ MDR_ANY = MDR_DG | MDR_GE | MDR_OV | MDR_PLEIADES | MDR_SPOT | MDR_RDK1 | MDR_LS | MDR_RE | MDR_KOMPSAT | MDR_EROS | MDR_ALOS /**< any reader */ } MDReaders; /** * The base class for all metadata readers */ class CPL_DLL GDALMDReaderBase { CPL_DISALLOW_COPY_ASSIGN(GDALMDReaderBase) static bool ReadXMLToListFirstPass(const CPLXMLNode *psNode, std::map &oMapCountKeysFull, const std::string &osPrefixFull, int nDepth); char **ReadXMLToList(const CPLXMLNode *psNode, char **papszList, const std::map &oMapCountKeysFullRef, std::map &oMapCountKeysFull, std::map &oMapCountKeys, const std::string &osPrefix, const std::string &osPrefixFull); public: GDALMDReaderBase(const char *pszPath, CSLConstList papszSiblingFiles); virtual ~GDALMDReaderBase(); /** * @brief Get specified metadata domain * @param pszDomain The metadata domain to return * @return List of metadata items */ virtual char **GetMetadataDomain(const char *pszDomain); /** * @brief Fill provided metadata store class * @param poMDMD Metadata store class * @return true on success or false */ virtual bool FillMetadata(GDALMultiDomainMetadata *poMDMD); /** * @brief Determine whether the input parameter correspond to the particular * provider of remote sensing data completely * @return True if all needed sources files found */ virtual bool HasRequiredFiles() const = 0; /** * @brief Get metadata file names. The caller become owner of returned list * and have to free it via CSLDestroy. * @return A file name list */ virtual char **GetMetadataFiles() const = 0; protected: /** * @brief Load metadata to the correspondent IMD, RPB, IMAGERY and DEFAULT * domains */ virtual void LoadMetadata(); /** * @brief Convert string like 2012-02-25T00:25:59.9440000Z to time * @param pszDateTime String to convert * @return value in second sinc epoch 1970-01-01 00:00:00 */ virtual GIntBig GetAcquisitionTimeFromString(const char *pszDateTime); /** * @brief ReadXMLToList Transform xml to list of NULL terminated name=value * strings * @param psNode A xml node to process * @param papszList A list to fill with name=value strings * @param pszName A name of parent node. For root xml node should be empty. * If name is not empty, the sibling nodes will not proceed * @return An input list filled with values */ virtual char **ReadXMLToList(CPLXMLNode *psNode, char **papszList, const char *pszName = ""); /** * @brief AddXMLNameValueToList Execute from ReadXMLToList to add name and * value to list. One can override this function for special * processing input values before add to list. * @param papszList A list to fill with name=value strings * @param pszName A name to add * @param pszValue A value to add * @return An input list filled with values */ virtual char **AddXMLNameValueToList(char **papszList, const char *pszName, const char *pszValue); protected: //! @cond Doxygen_Suppress char **m_papszIMDMD = nullptr; char **m_papszRPCMD = nullptr; char **m_papszIMAGERYMD = nullptr; char **m_papszDEFAULTMD = nullptr; bool m_bIsMetadataLoad = false; //! @endcond }; /** * The metadata reader main class. * The main purpose of this class is to provide an correspondent reader * for provided path. */ class CPL_DLL GDALMDReaderManager { CPL_DISALLOW_COPY_ASSIGN(GDALMDReaderManager) public: GDALMDReaderManager(); virtual ~GDALMDReaderManager(); /** * @brief Try to detect metadata reader correspondent to the provided * datasource path * @param pszPath a path to GDALDataset * @param papszSiblingFiles file list for metadata search purposes * @param nType a preferable reader type (may be the OR of MDReaders) * @return an appropriate reader or NULL if no such reader or error. * The pointer delete by the GDALMDReaderManager, so the user have not * delete it. */ virtual GDALMDReaderBase *GetReader(const char *pszPath, CSLConstList papszSiblingFiles, GUInt32 nType = MDR_ANY); protected: //! @cond Doxygen_Suppress GDALMDReaderBase *m_pReader = nullptr; //! @endcond }; // misc CPLString CPLStrip(const CPLString &osString, const char cChar); CPLString CPLStripQuotes(const CPLString &osString); char **GDALLoadRPBFile(const CPLString &osFilePath); char CPL_DLL **GDALLoadRPCFile(const CPLString &osFilePath); char **GDALLoadIMDFile(const CPLString &osFilePath); bool GDALCheckFileHeader(const CPLString &soFilePath, const char *pszTestString, int nBufferSize = 256); CPLErr GDALWriteRPBFile(const char *pszFilename, char **papszMD); CPLErr CPL_DLL GDALWriteRPCTXTFile(const char *pszFilename, char **papszMD); CPLErr GDALWriteIMDFile(const char *pszFilename, char **papszMD); #endif // GDAL_MDREADER_H_INCLUDED