arraypress / google-maps-embed
A PHP library for integrating with the Google Maps Embed API in WordPress, providing interactive map embeds with support for places, searches, directions, and street view. Features WordPress error handling and customizable iframe generation.
1.0.0
2024-12-19 19:34 UTC
Requires
- php: >=7.4
README
A PHP library for integrating with the Google Maps Embed API in WordPress, providing easy-to-use methods for embedding Google Maps with various modes including places, search, directions, street view, and standard views. Features WordPress integration, method chaining, and WP_Error
support.
Features
- πΊοΈ Multiple Embed Modes: Support for places, search, directions, view, and street view
- π Place Integration: Embed maps using Google Place IDs
- π Search Support: Embed maps with search queries
- π Directions: Show routes between locations
- π Street View: Embed street-level imagery
- β‘ WordPress Integration: Native WP_Error support and escaping
- π‘οΈ Type Safety: Full type hinting and strict types
- π¨ Customizable: Flexible iframe attributes and styling options
- π Global Support: Works with locations worldwide
- π Secure: Built-in security features including referrer policy
- π± Responsive: Support for responsive iframe attributes
- β¨ Easy Implementation: Simple, intuitive API methods
- π Method Chaining: Fluent interface for setting options
- βοΈ Validation: Built-in parameter validation for all setters
Requirements
- PHP 7.4 or later
- WordPress 5.0 or later
- Google Maps Embed API key
Installation
Install via Composer:
composer require arraypress/google-maps-embed
Basic Usage
use ArrayPress\Google\MapsEmbed\Client; // Initialize client with your API key $client = new Client( 'your-google-api-key' ); // Configure options using method chaining $client ->set_mode( 'driving' ) ->set_units( 'imperial' ) ->set_zoom( 15 ) ->set_language( 'en' ); // Embed a place using Place ID $place_url = $client->place( 'ChIJN1t_tDeuEmsRUsoyG83frY4' ); $iframe = $client->generate_iframe( $place_url ); // Embed a search result $search_url = $client->search( 'Coffee shops in Seattle' ); $iframe = $client->generate_iframe( $search_url ); // Embed directions $directions_url = $client->directions( 'Seattle, WA', 'Portland, OR' ); $iframe = $client->generate_iframe( $directions_url );
Configuration Methods
Setting Options
// Travel mode $client->set_mode( 'driving|walking|bicycling|transit' ); // Map type $client->set_map_type( 'roadmap|satellite' ); // Units $client->set_units( 'metric|imperial' ); // Route avoidance $client->set_avoid( ['tolls', 'highways', 'ferries'] ); // Zoom level (0-21) $client->set_zoom( 15 ); // Street view settings $client->set_heading( 90 ); // 0-360 degrees $client->set_pitch( -30 ); // -90 to 90 degrees $client->set_fov( 60 ); // 10-100 degrees // Localization $client->set_language( 'en' ); $client->set_region( 'US' ); // API key management $client->set_api_key( 'new-api-key' );
Getting Options
// Get current settings $mode = $client->get_mode(); $map_type = $client->get_map_type(); $units = $client->get_units(); $avoid = $client->get_avoid(); $zoom = $client->get_zoom(); $heading = $client->get_heading(); $pitch = $client->get_pitch(); $fov = $client->get_fov(); $language = $client->get_language(); $region = $client->get_region(); $api_key = $client->get_api_key(); // Get all options $all_options = $client->get_options(); // Reset options to defaults $client->reset_options();
Extended Examples
Embedding a Place
$client = new Client( 'your-api-key' ); // Basic place embed $place_url = $client ->set_zoom( 15 ) ->set_language( 'en' ) ->place( 'ChIJN1t_tDeuEmsRUsoyG83frY4' ); // Generate iframe with custom attributes $iframe = $client->generate_iframe( $place_url, [ 'width' => '800', 'height' => '600', 'class' => 'my-custom-map' ] );
Working with Different View Types
// Standard view using coordinates $view_url = $client ->set_zoom( 12 ) ->set_map_type( 'satellite' ) ->view( 47.6062, - 122.3321 ); // Street view with camera settings $street_url = $client ->set_heading( 90 ) ->set_pitch( 10 ) ->set_fov( 75 ) ->streetview( 47.6062, - 122.3321 ); // Search with specific parameters $search_url = $client ->set_zoom( 13 ) ->set_language( 'en' ) ->search( 'Parks in Seattle' );
Customizing the Iframe
$url = $client->place( 'ChIJN1t_tDeuEmsRUsoyG83frY4' ); $iframe = $client->generate_iframe( $url, [ 'width' => '100%', 'height' => '450', 'class' => 'google-map', 'id' => 'location-map', 'style' => 'border: 2px solid #ccc;', 'loading' => 'lazy', 'allowfullscreen' => true ] );
Handling Directions
// Configure options for directions $client ->set_mode( 'driving' ) ->set_avoid( [ 'tolls', 'highways' ] ) ->set_units( 'imperial' ) ->set_language( 'en' ); // Generate directions URL $directions_url = $client->directions( 'Seattle, WA', 'Portland, OR' );
API Methods
Client Methods
place( $place_id, $options = [] )
: Generate URL for place embedsearch( $query, $options = [] )
: Generate URL for search resultsview( $latitude, $longitude, $options = [] )
: Generate URL for map viewdirections( $origin, $destination, $options = [] )
: Generate URL for directionsstreetview( $latitude, $longitude, $options = [] )
: Generate URL for street viewgenerate_iframe( $url, $attrs = [] )
: Generate complete iframe HTML
Setters and Getters
- Travel Mode:
set_mode()
,get_mode()
- Map Type:
set_map_type()
,get_map_type()
- Units:
set_units()
,get_units()
- Avoid Routes:
set_avoid()
,get_avoid()
- Zoom Level:
set_zoom()
,get_zoom()
- Street View Camera:
set_heading()
,get_heading()
set_pitch()
,get_pitch()
set_fov()
,get_fov()
- Localization:
set_language()
,get_language()
set_region()
,get_region()
- API Management:
set_api_key()
,get_api_key()
get_options()
,reset_options()
Option Values
Travel Modes
driving
: Default driving directionswalking
: Walking directionsbicycling
: Bicycling directionstransit
: Public transit directions
Map Types
roadmap
: Default road map viewsatellite
: Satellite imagery
Units
metric
: Kilometers and metersimperial
: Miles and feet
Route Avoidance
tolls
: Avoid toll roadshighways
: Avoid highwaysferries
: Avoid ferries
Use Cases
- Business Locations: Display store or office locations
- Event Maps: Show event venues and directions
- Property Listings: Display real estate locations
- Travel Planning: Show routes and destinations
- Location Discovery: Embed searchable maps
- Virtual Tours: Street view integration
- Contact Pages: Display business locations
- Directory Listings: Show multiple locations
- Travel Guides: Display tourist destinations
- Store Locators: Help customers find locations
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
This project is licensed under the GPL-2.0-or-later License.