Saturday, February 20, 2010

Integrating Google Maps in an APEX Application

Here is how you can integrate Google Maps in an APEX Application.This video was created using the PDF document available at URL http://www.oracle.com/technology/products/database/application_express/pdf/Integrating_Application_Express_with_Google_Maps.pdf . Some of the codes were changed to make it work in the demonstrated scenario. This Google map was integrated in "Add/Modify Customers" page of Sample Application.

Tip
1. Click on play and select '720p' from the toolbar to view the video in high resolution
2. Click on icon  to view the video in full screen



These are the steps involved in integrating Google Maps in your APEX Application

1. Embedding Google Maps is accomplished using JavaScript to invoke the Google Maps API. So the first step is sign up for the Google Maps API Key, which is required to use the API in your application. You can sign up for API Key at URL http://code.google.com/apis/maps/signup.html
2. Create substitution string in your APEX application for the API Key
3. Edit the page where you want to show Google Maps. Add 3 items to the page that will store the location co-ordinates.
4. Create a process "Call Google Geocode Service" to get the location co-ordinates based on customer's address

DECLARE
   l_address   VARCHAR2(4000);
   l_url       VARCHAR2(32000);
   l_response  VARCHAR2(3200);
BEGIN 
   l_address := :P7_CUST_STREET_ADDRESS1 ;
   IF :P7_CUST_CITY IS NOT NULL THEN
      l_address := l_address || ',' || :P7_CUST_CITY ;
   END IF;
   IF :P7_CUST_STATE IS NOT NULL THEN
      l_address := l_address || ',' || :P7_CUST_STATE ;
   END IF;
   IF :P7_CUST_POSTAL_CODE IS NOT NULL THEN
      l_address := l_address || ',' || :P7_CUST_POSTAL_CODE ;
   END IF;  
   l_address := REPLACE(l_address,' ','+');
   l_url := 'http://maps.google.com/maps/geo?q='||l_address||'&'||'output=csv'||'&'||'key='||:API_KEY;
   l_response := UTL_HTTP.REQUEST(l_url, APEX_APPLICATION.G_PROXY_SERVER);
   :P7_RESPONSE  := l_response;
   :P7_LATITUDE  := SUBSTR(l_response,INSTR(l_response,',',1,2)+1,(INSTR(l_response,',',1,3)-INSTR(l_response,',',1,2))-1);
   :P7_LONGTITUDE := SUBSTR(l_response,INSTR(l_response,',',1,3)+1);
END;

5. Create a process to get the location co-ordinates based on customer's address
6. Add a region to the page to display map. Set the region source to following

<div id="map" style="width: 600px; height: 400px"></div>

7. Add JavaScript to the HTML Header attribute of the page

<script src="http://maps.google.com/maps?file=api&v=2&key=&API_KEY." type="text/javascript"></script>
<script type="text/javascript">
//<![CDATA[
//globals
var bounds = new GLatLngBounds();
function initMap() {
if (GBrowserIsCompatible()) {
var map = new GMap2(document.getElementById("map"));
var title = "&P7_CUST_STREET_ADDRESS1.";
map.addControl(new GSmallMapControl());
map.addControl(new GMapTypeControl());
var point = new GLatLng($v('P7_LATITUDE'),$v('P7_LONGTITUDE'));
bounds.extend(point);
map.setCenter(point);
map.setZoom(map.getBoundsZoomLevel(bounds)-4);
var marker = new GMarker(point);
map.addOverlay(marker);
}
}
//]]>
</script>

8. Add the following onload event HTML Body Attribute of the page.

onload="initMap()" onunload="GUnload()"

35 comments:

Robate said...

Online instructional program

Online degrees sound great, and many universities are building the technology to offer distance learning programs. Yet, some universities still require you to use other mediums to obtain your online degrees besides your computer. Some programs require you to use video or telephone conferencing that are less effective. The best online degrees are earned from universities that are fully taught online. Being fully taught via the internet also means that you should look at online degree programs that are taught by qualified professors. Many online programs only hire local teachers………….

www.sangambayard-c-m.com

玉苓 said...

以簡單的行為愉悅他人的心靈,勝過千人低頭禱告........................................

冠樺冠樺 said...

嘿,你的部落格不錯哦!........................................

童紫勳 said...

希望能常常看到你的更新 .........................................

曾嘉慧 said...

沈舟側畔千帆過,病樹前頭萬木春......................................................

PorshaCoghlan梁子珠 said...

sex女,ut,貼影,av,高潮,女優,做愛,手機成人影片,色遊戲,成人動漫,百分百貼圖區,85cc影片,成人影音,av色情影片,A片線上,a片,sex,777,三級線上看,美女的照片,視訊做愛,78論壇,打飛機,免費視訊,成人影院,辣妹視訊,視訊聊天,影片網,kiss911,a片,交友,聊天,做愛,免費影片,性交,線上成人,網路色情,聊天,美女自慰,免費a分享,免費短片,裸照,一夜情,女優,85cc成人片,美女寫真,偷拍a,情人視訊聊天室

BokHaile8854 said...

天下沒有走不通的路,沒有克服不了的困難,沒有打不敗的敵人。........................................

嘉琬 said...

人間好話,要如海綿遇水牢牢吸住......................................................

韋于倫成 said...

死亡是悲哀的,但活得不快樂更悲哀。..................................................

柏強 said...

一夜情視訊網際論壇一夜激情聊天室一對多美女視訊一對一視訊一對一視訊聊天一對一視訊辣妹妹影音視訊聊天室一本道 a片 東京熱avdvd影片一本道 a片 東京熱av免費影片一本道 a片 東京熱免費成人影片觀賞一本道 a片 東京熱成人圖片區亞洲禁果名模影城甜心寶貝直播貼片玩美女人視訊網美女短片免費試看視訊交友網50024彩虹avdvdsex888免費看影片亞亞 dvd 光碟百事免費av視訊聊天網免費線上 aa 片試看85CCsex貼片網s383情色大網咖熟女自拍sex免費成人影片情境坊歡愉用品 視訊泳裝秀拓網交友免費成人影片,104免費成人情色文學小說視訊主播脫衣秀gogo2sexplus28論壇米克綜合論壇聊天室交友av成人網g8mm 視訊壞朋友論壇視訊美女msvt中部人聊天室視訊網愛聊天室網路援交168論壇辣妹貼圖新竹援交38ga片下載

逸凡 said...

責人之心責己,恕己之心恕人。 ....................................................

SadeRa盈君iford0412 said...

只用微笑說話的人,才能擔當重任。........................................

淑慧 said...

It is easier to get than to keep it...................................................................

玉龍玉龍 said...

It is easier to get than to keep it...................................................................

玫友 said...

Pen and ink is wits plough. .................................................................                           

銘木 said...

在莫非定律中有項笨蛋定律:「一個組織中的笨蛋,恆大於等於三分之二。」......................................................................

佳皓佳皓 said...

向著星球長驅直進的人,反比踟躕在峽路上的人,更容易達到目的。............................................................

育隆 said...

留言是種美德-感謝分享..................................................................

姿柯瑩柯dgdd憶曾g智曾 said...

People throw stones only at trees with fruit on them.............................................................

楊儀卉 said...

文章這麼好,怎麼可以不踩!............................................................

江桂宸江桂宸 said...

喜歡你的部落格,祝你愈來愈好............................................................

姿柯瑩柯dgdd憶曾g智曾 said...

Knowledge is a treasure, but practice is the key to it.............................................................

黃威宇 said...

教育的目的,不在應該思考什麼,而是教吾人怎樣思考............................................................

珮瑜 said...

不斷的砍伐用的雖是小斧,卻能砍倒最堅硬的橡樹。.......................................................

周伯啟江彥璋 said...

人生有些波折,才能有些成長,所以不論順逆,凡是成長、成功的助緣,都應該心存感激。..................................................

曹初帆張武茜 said...

Make yourself necessary to someone..................................................................

仲惠娟惠娟亨 said...

人生中最好的禮物就是屬於自己的一部份............................................................

家唐銘 said...

More haste, less speed..................................................................

王李慧萍政勳 said...

Lets cross the bridge when we come to it............................................................

承王蓁 said...

上班好累哦,看看部落格轉換心情~~~先謝謝啦!!............................................................

蕭林馥賢琬婷 said...

你文章很棒的~繼續分享給大家~~~~..................................................

阿袁袁袁袁華 said...

謝謝您的分享~~好文值得收藏!!..................................................................

翊翊翊翊張瑜翊翊翊 said...

人們不缺少力量,他們缺少意志。..................................................

翊翊翊翊張瑜翊翊翊 said...

世間事沒有一樣沒有困難,只要有信心去做,至少可以做出一些成績。..................................................

SadeRa盈君iford0412 said...

若有人問你成功時會不會記得他 試問若你失敗時他會不會記得你......................................................................