Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8649917
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 12, 20262026-06-12T13:40:49+00:00 2026-06-12T13:40:49+00:00

I need to display an interactive map with zip codes showing their boundaries and

  • 0

I need to display an interactive map with zip codes showing their boundaries and have different colors for the zip codes like this:

http://www.usnaviguide.com/zip.htm

Enter in a US zip code and click on “Find Zip code”.

Perhaps I am overlooking it, but I’ve not been to find examples of this and documentation talking about this specifically at Google Maps API documentation. I’ve trying doing a view source on the above web page link, but it doesn’t seem obvious to me how it works. There is also other stuff on the page which I don’t know if it’s part of what I need or not.

Some simple code examples would be very helpful! Thanks!

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-12T13:40:50+00:00Added an answer on June 12, 2026 at 1:40 pm

    Here is a zipcode map for the US that I put together with FusionTablesLayers:

    http://www.geocodezip.com/geoxml3_test/v3_FusionTables_zipcode_map.html

    It doesn’t have different colors, but you could change that.

    John Coryat made that map using a tile server, you can do the same with Google Maps API v3 custom maps.

    code snippet from example:

    google.load('visualization', '1', {'packages':['corechart', 'table', 'geomap']});
    var map;
    var labels = [];
    var layer;
    var tableid =  1499916;
    
    function initialize() {
        geocoder = new google.maps.Geocoder();
      	map = new google.maps.Map(document.getElementById('map_canvas'), {
        center: new google.maps.LatLng(37.23032838760389, -118.65234375),
        zoom: 6,
        mapTypeId: google.maps.MapTypeId.ROADMAP
      });
      
      layer = new google.maps.FusionTablesLayer(tableid);
      layer.setQuery("SELECT 'geometry' FROM " + tableid);
      layer.setMap(map);
    
      codeAddress("11501" /*document.getElementById("address").value*/ );
    
      google.maps.event.addListener(map, "bounds_changed", function() {
        displayZips();
      });
      google.maps.event.addListener(map, "zoom_changed", function() {
        if (map.getZoom() < 11) {
          for (var i=0; i<labels.length; i++) {
            labels[i].setMap(null);
          }
        }
      });
    }
    
    function codeAddress(address) {
        geocoder.geocode( { 'address': address}, function(results, status) {
          if (status == google.maps.GeocoderStatus.OK) {
            map.setCenter(results[0].geometry.location);
            var marker = new google.maps.Marker({
                map: map, 
                position: results[0].geometry.location
            });
            if (results[0].geometry.viewport) 
              map.fitBounds(results[0].geometry.viewport);
          } else {
            alert("Geocode was not successful for the following reason: " + status);
          }
        });
      }
      		
    function displayZips() {
      //set the query using the current bounds
      var queryStr = "SELECT geometry, ZIP, latitude, longitude FROM "+ tableid + " WHERE ST_INTERSECTS(geometry, RECTANGLE(LATLNG"+map.getBounds().getSouthWest()+",LATLNG"+map.getBounds().getNorthEast()+"))";   
      var queryText = encodeURIComponent(queryStr);
      var query = new google.visualization.Query('http://www.google.com/fusiontables/gvizdata?tq='  + queryText);
      // alert(queryStr);
    
      //set the callback function
      query.send(displayZipText);
    
    }
     
    
      var infowindow = new google.maps.InfoWindow();
    		
    function displayZipText(response) {
    if (!response) {
      alert('no response');
      return;
    }
    if (response.isError()) {
      alert('Error in query: ' + response.getMessage() + ' ' + response.getDetailedMessage());
      return;
    } 
      if (map.getZoom() < 11) return;
      FTresponse = response;
      //for more information on the response object, see the documentation
      //http://code.google.com/apis/visualization/documentation/reference.html#QueryResponse
      numRows = response.getDataTable().getNumberOfRows();
      numCols = response.getDataTable().getNumberOfColumns();
    /*  var queryStr = "SELECT geometry, ZIP, latitude, longitude FROM "+ tableid + " WHERE ST_INTERSECTS(geometry, RECTANGLE(LATLNG"+map.getBounds().getSouthWest()+",LATLNG"+map.getBounds().getNorthEast()+"))";   
    */
    
      for(i = 0; i < numRows; i++) {
          var zip = response.getDataTable().getValue(i, 1);
          var zipStr = zip.toString()
          while (zipStr.length < 5) { zipStr = '0' + zipStr; }
          var point = new google.maps.LatLng(
              parseFloat(response.getDataTable().getValue(i, 2)),
              parseFloat(response.getDataTable().getValue(i, 3)));
          // bounds.extend(point);
          labels.push(new InfoBox({
    	 content: zipStr
    	,boxStyle: {
    	   border: "1px solid black"
    	  ,textAlign: "center"
              ,backgroundColor:"white"
    	  ,fontSize: "8pt"
    	  ,width: "50px"
    	 }
    	,disableAutoPan: true
    	,pixelOffset: new google.maps.Size(-25, 0)
    	,position: point
    	,closeBoxURL: ""
    	,isHidden: false
    	,enableEventPropagation: true
          }));
          labels[labels.length-1].open(map);
      }
      // zoom to the bounds
      // map.fitBounds(bounds);
    }
    
    google.maps.event.addDomListener(window,'load',initialize);
    #map_canvas { width: 610px; height: 400px; }
    <script type="text/javascript" src="http://www.google.com/jsapi"></script>         
    <script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script>
    <script type="text/javascript" src="http://google-maps-utility-library-v3.googlecode.com/svn/trunk/infobox/src/infobox.js"></script>
    <script type="text/javascript" src="http://geoxml3.googlecode.com/svn/branches/polys/geoxml3.js"></script>
    
    
    <form> 
     	    <span class="style51"><span class="style49">Show</span>:</span> 
    <input id="address" type="text" value="11501" ></input>
    <input id="geocode" type="button" onclick="codeAddress(document.getElementById('address').value);" value="Geocode"></input>	  
    <div id="map_canvas"></div>
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

i am developing one application with map view i need display the weather depends
I need to display short description like label and near it data associated with
I need to display array of images in a single view which have various
I need to create an interactive world map on the front page of a
I have a set of 36 car images which I need to be interactive.
I have a neo4j DB in my backend and I would like to display
I have a slippy map over which I want to display a overlay with
I need some tool to display text containing ANSI codes correctly on Windows. No
I have a Java applet which displays an interactive map. By using the scroll
I need to display both color coded states and cities on a US map.

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.