18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
# File 'lib/adiwg/mdtranslator/readers/fgdc/modules/module_localSystem.rb', line 18
def self.unpack(xLocal, hResponseObj)
intMetadataClass = InternalMetadata.new
hProjection = intMetadataClass.newProjection
hIdentifier = intMetadataClass.newIdentifier
hLocal = intMetadataClass.newLocal
hProjection[:projectionIdentifier] = hIdentifier
hProjection[:local] = hLocal
hIdentifier[:identifier] = 'localSystem'
hIdentifier[:name] = 'Local Coordinate System'
hLocal[:fixedToEarth] = false
description = xLocal.xpath('./localdes').text
unless description.empty?
hLocal[:description] = description
end
if description.empty?
hResponseObj[:readerExecutionMessages] <<
'WARNING: FGDC reader: local coordinate system description is missing'
end
georeference = xLocal.xpath('./localgeo').text
unless georeference.empty?
hLocal[:georeference] = georeference
end
if georeference.empty?
hResponseObj[:readerExecutionMessages] <<
'WARNING: FGDC reader: local coordinate system georeference information is missing'
end
hReferenceSystem = intMetadataClass.newSpatialReferenceSystem
hSystemParameters = intMetadataClass.newReferenceSystemParameterSet
hSystemParameters[:projection] = hProjection
hReferenceSystem[:systemParameterSet] = hSystemParameters
return hReferenceSystem
end
|