plin-code / kml-parser
A Laravel package to parse KML and KMZ files
Fund package maintenance!
PlinCode
Requires
- php: ^8.3
- ext-libxml: *
- ext-simplexml: *
- ext-zip: *
- illuminate/contracts: ^11.0||^12.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1
- orchestra/testbench: ^10.0.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-arch: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
- phpstan/extension-installer: ^1.3||^2.0
- phpstan/phpstan-deprecation-rules: ^1.1||^2.0
- phpstan/phpstan-phpunit: ^1.3||^2.0
This package is not auto-updated.
Last update: 2025-05-10 16:54:00 UTC
README
A simple Laravel package to parse KML and KMZ files, extracting geographic data in a convenient format.
Installation
You can install the package via composer:
composer require plin-code/kml-parser
You can publish the config file with:
php artisan vendor:publish --tag="kml-parser-config"
This is the contents of the published config file:
return [ /* |-------------------------------------------------------------------------- | Default KML Namespace |-------------------------------------------------------------------------- | | This value is the default namespace used for parsing KML files. | Usually you don't need to change this. | */ 'namespace' => 'http://www.opengis.net/kml/2.2', /* |-------------------------------------------------------------------------- | Temporary Directory |-------------------------------------------------------------------------- | | This value determines the temporary directory used for extracting KMZ files. | If null, the system temp directory will be used. | */ 'temp_directory' => null, ];
Usage
Basic Usage
use PlinCode\KmlParser\KmlParser; // Parse a KML file $parser = new KmlParser(); $parser->loadFromFile('path/to/file.kml'); // Get placemarks (points of interest) $placemarks = $parser->getPlacemarks(); // Get styles $styles = $parser->getStyles(); // Get style maps $styleMaps = $parser->getStyleMaps(); // Get document name and description $name = $parser->getDocumentName(); $description = $parser->getDocumentDescription(); // Convert to GeoJSON $geoJson = $parser->toGeoJson();
Working with KMZ Files
KMZ files are ZIP archives that contain a KML file and possibly other assets like images:
// Parse a KMZ file $parser = new KmlParser(); $parser->loadFromKmz('path/to/file.kmz'); // Work with the data just like with KML $placemarks = $parser->getPlacemarks();
Extract all files from a KMZ:
use PlinCode\KmlParser\KmzExtractor; $extractor = new KmzExtractor(); $files = $extractor->extractAllFiles('path/to/file.kmz', 'extraction/directory');
Facade Usage
You can also use the provided facade:
use PlinCode\KmlParser\Facades\KmlParser; $placemarks = KmlParser::loadFromFile('path/to/file.kml')->getPlacemarks();
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.