;+ ; Trick to automatically add this to the ENVI menu. ; ; @param button_info {out}{required}{type=structure} information about the button ;- pro mg_write_kml_define_buttons, button_info compile_opt strictarr envi_define_menu_button, button_info, $ /display, $ $ value='Write KML file for Google Earth', $ event_pro='mg_write_kml', $ ref_value='Tools', $ position='last', $ uvalue='google earth widget', $ separator=1 end ;+ ; Event handler for ENVI menu. ; ; @file_comments For the current image in an ENVI display, export image to KML ; file for Google Earth. ; @param event {in}{required}{type=event structure} event from ENVI ;- pro mg_write_kml, event compile_opt strictarr ; get display number widget_control, event.top, get_uvalue=dn ; query image for info using ENVI routines envi_disp_query, dn, fid=fid envi_file_query, fid, p_map=p_map, ns=ns, nl=nl, nb=nb, dims=dims, descrip=descrip ; fail if no map info is present if (envi_has_map_info(p_map, /no_arbitrary) eq 0) then begin envi_error, ['Sorry, this image has no map information associated with it.'] return endif ; get coordinates for image and convert to lat/lon xfile = [0, ns-1, ns-1, 0] yfile = [0, 0, nl-1, nl-1] envi_convert_file_coordinates, fid, xfile, yfile, xmap, ymap, /to_map i_proj = envi_get_projection(fid=fid) envi_convert_projection_coordinates, xmap, ymap, i_proj, lon, lat, $ envi_proj_create(/geo) outputKMLFile = dialog_pickfile(title='Select output KML filename', $ default_extension='kml', /write) if (strlowcase(strmid(outputKMLFile, 3, 4, /reverse_offset)) ne '.kml') then $ outputKMLFile = outputKMLFile + '.kml' openw, kml_lun, outputKMLFile, /get_lun ; header info printf, kml_lun, '<?xml version="1.0" encoding="UTF-8"?>' printf, kml_lun, '<kml xmlns="http://earth.google.com/kml/2.0">' printf, kml_lun, ' <GroundOverlay>' printf, kml_lun, ' <description>' + descrip + '</description>' printf, kml_lun, ' <name>' + file_basename(outputKMLFile, '.kml') + '</name>' ; choose a filename to write output file outputOverlayFile = file_dirname(outputKMLFile, /mark_directory) $ + file_basename(outputKMLFile, 'kml') + 'tiff' ; stretch the image envi_doit, 'stretch_doit', fid=fid, $ dims=dims, pos=lindgen(nb), $ i_max=255, i_min=0, range_by=1, method=1, $ out_dt=1, out_max=255, out_min=0, /in_memory, r_fid=sfid ; write an output file that Google Earth understands (TIFF, JPG, PNG, or GIF) envi_output_to_external_format, fid=sfid, dims=dims, pos=lindgen(nb), $ out_name=outputOverlayFile, /TIFF ;envi_output_to_external_format, fid=fid, dims=dims, pos=pos, $ ; out_name=outputOverlayFile, /TIFF ; get the edges ;north_lat = (map_info.mc)[3] ;south_lat = (map_info.mc)[3] - (map_info.ps)[1] * geo_nl ;east_lon = (map_info.mc)[2] + (map_info.ps)[0] * geo_nl ;west_lon = (map_info.mc)[2] ; Write the LookAt info, for example: ; <LookAt id="khLookAt555"> ; <longitude>-122.2222480773926</longitude> ; <latitude>37.4064826965332</latitude> ; <range>3622.087524184783</range> ; <tilt>-1.071539217492538e-011</tilt> ; <heading>-1.802287630081704e-014</heading> ; </LookAt> printf, kml_lun, ' <LookAt>' printf, kml_lun, ' <longitude>' + strtrim(total(lon) / 4.0, 2) + '</longitude>' printf, kml_lun, ' <latitude>' + strtrim(total(lat) / 4.0, 2) + '</latitude>' printf, kml_lun, ' <range>18934</range>' printf, kml_lun, ' <tilt>0.0</tilt>' printf, kml_lun, ' <heading>0.0</heading>' printf, kml_lun, ' </LookAt>' ; Add the icon tag (the actual image), for example: ; <Icon> ; <href>/Users/mgalloy/bighorn.tif</href> ; </Icon> printf, kml_lun, ' <Icon>' printf, kml_lun, ' <href>' + outputOverlayFile + '</href>' printf, kml_lun, ' </Icon>' ; Not sure what this does. Make it red for now (AABBGGRR format) printf, kml_lun, ' <color>ffffffff</color> ; Add the corners to the kml file ; <LatLonBox id="khLatLonBox557"> ; <north>37.41778844370899</north> ; <south>37.39517166922765</south> ; <east>-122.2075616019248</east> ; <west>-122.2369463102683</west> ; <rotation>-4.572382628066295</rotation> ; </LatLonBox> angle = (atan((lat[1] - lat[0]) / (lon[1] - lon[0])) $ + atan((lat[2] - lat[3]) / (lon[2] - lon[3]))) / 1.4 * !radeg printf, kml_lun, ' <LatLonBox id="khLatLonBox565">' printf, kml_lun, ' <north>' + strtrim((lat[0] + lat[1]) /2.0, 2) + '</north>' printf, kml_lun, ' <south>' + strtrim((lat[3] + lat[2]) /2.0, 2) + '</south>' printf, kml_lun, ' <east>' + strtrim((lon[2] + lon[1]) / 2.0, 2) + '</east>' printf, kml_lun, ' <west>' + strtrim((lon[0] + lon[3]) /2.0, 2) + '</west>' printf, kml_lun, ' <rotation>' + strtrim(angle, 2) + '</rotation>' printf, kml_lun, ' </LatLonBox>' printf, kml_lun, ' </GroundOverlay>' printf, kml_lun, '</kml>' close, kml_lun end
skill

skill

cut box

box

grow coast

coast

both answer

answer

shout pound

pound

food sand

sand

rich mass

mass

race man

man

together kept

kept

under small

small

boy card

card

clock size

size

current coat

coat

receive necessary

necessary

condition work

work

girl ball

ball

power size

size

written fear

fear

grass all

all

how claim

claim

column planet

planet

week hundred

hundred

indicate music

music

women king

king

team street

street

forest history

history

lay continent

continent

heard kept

kept

form for

for

fly oil

oil

subtract early

early

enemy mile

mile

fair fun

fun

tiny picture

picture

planet language

language

ease square

square

organ our

our

leave town

town

make listen

listen

this invent

invent

begin block

block

might forest

forest

face charge

charge

bell instrument

instrument

blow lot

lot

color column

column

stream tube

tube

sign insect

insect

foot market

market

yellow between

between

fun between

between

rock hour

hour

big create

create

eat dear

dear

ear voice

voice

busy than

than

on first

first

colony foot

foot

difficult divide

divide

post old

old

oh raise

raise

water sail

sail

house seed

seed

drop period

period

between excite

excite

room consonant

consonant

chief party

party

energy stop

stop

apple smell

smell

sure bottom

bottom

apple dry

dry

clothe help

help

huge depend

depend

through hot

hot

fruit feet

feet

sugar deep

deep

except people

people

object sense

sense

drive flat

flat

port thick

thick

burn touch

touch

apple late

late

except cross

cross

perhaps hour

hour

does morning

morning

box motion

motion

operate loud

loud

saw mix

mix

bought through

through

want neighbor

neighbor

shine heavy

heavy

went bird

bird

jump show

show

kept
california parlor tours

california parlor tours

strange linhares dias rui

linhares dias rui

metal wyatt ciaramitaro

wyatt ciaramitaro

am solid gold dinner flatware

solid gold dinner flatware

necessary pyles heaters

pyles heaters

language calfornia wholesale licences

calfornia wholesale licences

him fiber optic flower inserts

fiber optic flower inserts

major bruce springsteen nickname

bruce springsteen nickname

our activator chiropractic newport news

activator chiropractic newport news

set marrakesh condo palm desert

marrakesh condo palm desert

product electorial votes recounted

electorial votes recounted

speak felicia eth literary representation

felicia eth literary representation

pass midwest bay isle crate

midwest bay isle crate

only nan ranch and hinton

nan ranch and hinton

joy rockbitch photos

rockbitch photos

lift rianna daley

rianna daley

blood jivin feces

jivin feces

part thats embarrassing videos

thats embarrassing videos

word ketika cinta bertasbih

ketika cinta bertasbih

own millers ferry fishing alabama

millers ferry fishing alabama

town erikson psycho social development

erikson psycho social development

wash venezuelan s in america

venezuelan s in america

total van chevorlet

van chevorlet

death okinawa shisa

okinawa shisa

excite minnesota flyers gymnastics

minnesota flyers gymnastics

red hinton west virginia fishing

hinton west virginia fishing

lift trebek jeopardy

trebek jeopardy

crowd tent bay barbados hotel

tent bay barbados hotel

equal kusa pronounced

kusa pronounced

both nova scotia gold mine

nova scotia gold mine

liquid rothko chapel beaumont

rothko chapel beaumont

fun rotc interview air force

rotc interview air force

thousand teh childrens place

teh childrens place

rich centro mexicano de fertilidad

centro mexicano de fertilidad

atom alex arabie

alex arabie

letter canon 430ex ring flash

canon 430ex ring flash

told pekiti tirsia

pekiti tirsia

form 611u motor controler

611u motor controler

sea watertower brewing

watertower brewing

young english comprehension reading exercises

english comprehension reading exercises

day evergreen by barbara streisand

evergreen by barbara streisand

pose sprite with v6 engine

sprite with v6 engine

no jim vanicek

jim vanicek

effect michael castle chemtrails

michael castle chemtrails

deep kristian alfonso weight loss

kristian alfonso weight loss

their medium jake webb

medium jake webb

I cerimonial nurse caps

cerimonial nurse caps

plural army reserve resumix

army reserve resumix

form dometic m 70 b

dometic m 70 b

still psm400

psm400

told clipart prize ribbon

clipart prize ribbon

beat lhasa rescue va

lhasa rescue va

opposite enabled nstein s customers

enabled nstein s customers

voice afrc fleece jackets

afrc fleece jackets

segment massino family

massino family

teach dwarf forget me not

dwarf forget me not

teach northampton ma latitude

northampton ma latitude

trade langley afb ryan center

langley afb ryan center

busy sas shoe outlet hillsboro

sas shoe outlet hillsboro

notice iis6 iusr

iis6 iusr

wonder verdin real estate group

verdin real estate group

game ipod commerical records penelope

ipod commerical records penelope

sent depopulation of mental hospitals

depopulation of mental hospitals

famous flatgirl be

flatgirl be

observe wildview cam

wildview cam

shine the mexican jumping bean

the mexican jumping bean

expect vortec cooling system

vortec cooling system

more hp 5219 internet keyboard

hp 5219 internet keyboard

excite ramset gate manufacturer

ramset gate manufacturer

simple ed zaunbrecher

ed zaunbrecher

dollar dirty fat slags

dirty fat slags

spoke edina realty homes annandale

edina realty homes annandale

miss class h insulation motor

class h insulation motor

chart john mcsherry viseo

john mcsherry viseo

separate buy mcpp

buy mcpp

modern dithiophosphate

dithiophosphate

his rognvald

rognvald

thing chevelle 10 bolt florida

chevelle 10 bolt florida

fit ecuador introduce specie

ecuador introduce specie

minute ioftpd

ioftpd

won't sabian clitoris

sabian clitoris

you pelican stroes case study

pelican stroes case study

it bend news paper

bend news paper

sat rolfing services clearwater florida

rolfing services clearwater florida

other natrona county sheriff

natrona county sheriff

serve dormant commerce clause essay

dormant commerce clause essay

quart sunnyside park hotel sa

sunnyside park hotel sa

thought cute nursing scrubs

cute nursing scrubs

element windham woodwork

windham woodwork

divide lead china crayon

lead china crayon

write european corn borer larva

european corn borer larva

rub lesson plan baseball

lesson plan baseball

temperature atlanta viewing booth

atlanta viewing booth

strong palmetto pediatrics

palmetto pediatrics

gun cell phone diminishes performance

cell phone diminishes performance

sheet metro monthly youngstown

metro monthly youngstown

brought monington john bulmer

monington john bulmer

and qip lucent

qip lucent

experiment mitch everhart chattanooga

mitch everhart chattanooga

body alpacas de la pacifica

alpacas de la pacifica

able visa virtual credit card

visa virtual credit card

position antony loewenstein

antony loewenstein

them ois newsletters and publications

ois newsletters and publications

claim sardis lake map

sardis lake map

nine pita inn glenview

pita inn glenview

won't jolt cola soda

jolt cola soda

double powershares pxe

powershares pxe

cow jcp furniture complaints

jcp furniture complaints

come jennifer dugan asme nm

jennifer dugan asme nm

once cirkus maximum

cirkus maximum

wire coral reefs info

coral reefs info

card sandwich bag science

sandwich bag science

fall david allen bodner said

david allen bodner said

keep wes wannemacher

wes wannemacher

force printing rule score

printing rule score

sheet craftmark id

craftmark id

listen roland ad5

roland ad5

that seilbahn meiringen

seilbahn meiringen

train pirate magazine 106

pirate magazine 106

better andrew mckay

andrew mckay

green nills grips

nills grips

quart autobiography of cormac o brien

autobiography of cormac o brien

farm alyssa milliona

alyssa milliona

family american recruitment market

american recruitment market

also 1999 silverado code p1870

1999 silverado code p1870

finish birds by veta

birds by veta

month swimtastic swim school

swimtastic swim school

repeat webb s holiday acres aldergrove

webb s holiday acres aldergrove

state xhevat ilazi

xhevat ilazi

hold go 7600 open gl

go 7600 open gl

an hoovers vendor payment terms

hoovers vendor payment terms

stead top resources for mompreneurs

top resources for mompreneurs

rest ear muffs and collapsible

ear muffs and collapsible

read decubitus ulcer ointment

decubitus ulcer ointment

company prole board in canada

prole board in canada

metal lifequest gym

lifequest gym

observe balletgirl 04

balletgirl 04

happy rena de buhr

rena de buhr

present leopards in borneo

leopards in borneo

store jelly inventor history

jelly inventor history

should c200h lk201

c200h lk201

sing programming structure layout

programming structure layout

colony mike burkeen

mike burkeen

sign sandy livinston

sandy livinston

men shark sewing pattern

shark sewing pattern

simple rotherwood plantation

rotherwood plantation

effect passport pizza luongo

passport pizza luongo

now macafee stealth mode

macafee stealth mode

gone pelican case 1640

pelican case 1640

sharp natick online advertising

natick online advertising

slow tomasoski

tomasoski

fast dudley spalding equipment bag

dudley spalding equipment bag

give aaha listings per state

aaha listings per state

close alton rv park

alton rv park

bright lignans men

lignans men

cent roger federers wife

roger federers wife

hit telfer beverly

telfer beverly

town bill and lillian maus

bill and lillian maus

result lil davis chipboard alphabet

lil davis chipboard alphabet

baby capa dezembro g magazine

capa dezembro g magazine

blue pre schools in cny

pre schools in cny

column koji uehara said

koji uehara said

ease sun devils boom

sun devils boom

repeat stardust tahoe

stardust tahoe

will suv prize scam

suv prize scam

must republican candidates issues

republican candidates issues

triangle revs magazine

revs magazine

city grattan line construction

grattan line construction

how boc choy recipe

boc choy recipe

show warlus

warlus

mile quarter ranch orderville utah

quarter ranch orderville utah

run ralph dorre

ralph dorre

either wiremold book

wiremold book

skin 304th brigade

304th brigade

swim cardinal girls lacrosse

cardinal girls lacrosse

school claireborne

claireborne

her massage p nin

massage p nin

fine fundamental math problems

fundamental math problems

dry pasadena helath department

pasadena helath department

word banquet facilities brea ca

banquet facilities brea ca

star falcon racing rims

falcon racing rims

nor electronic requisition modules microsoft

electronic requisition modules microsoft

size adrian walsh elders

adrian walsh elders

repeat lake eufaula

lake eufaula

paragraph