/* * Copyright 2008 ZXing authors * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ using System; using Result = com.google.zxing.Result; namespace com.google.zxing.client.result { /// Parses a "geo:" URI result, which specifies a location on the surface of /// the Earth as well as an optional altitude above the surface. See /// /// http://tools.ietf.org/html/draft-mayrhofer-geo-uri-00. /// /// /// Sean Owen /// /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source /// sealed class GeoResultParser:ResultParser { private GeoResultParser() { } public static GeoParsedResult parse(Result result) { System.String rawText = result.Text; if (rawText == null || (!rawText.StartsWith("geo:") && !rawText.StartsWith("GEO:"))) { return null; } // Drop geo, query portion //UPGRADE_WARNING: Method 'java.lang.String.indexOf' was converted to 'System.String.IndexOf' which may throw an exception. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1101'" int queryStart = rawText.IndexOf('?', 4); System.String geoURIWithoutQuery = queryStart < 0?rawText.Substring(4):rawText.Substring(4, (queryStart) - (4)); int latitudeEnd = geoURIWithoutQuery.IndexOf(','); if (latitudeEnd < 0) { return null; } //UPGRADE_WARNING: Method 'java.lang.String.indexOf' was converted to 'System.String.IndexOf' which may throw an exception. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1101'" int longitudeEnd = geoURIWithoutQuery.IndexOf(',', latitudeEnd + 1); double latitude, longitude, altitude; try { latitude = System.Double.Parse(geoURIWithoutQuery.Substring(0, (latitudeEnd) - (0))); if (longitudeEnd < 0) { longitude = System.Double.Parse(geoURIWithoutQuery.Substring(latitudeEnd + 1)); altitude = 0.0; } else { longitude = System.Double.Parse(geoURIWithoutQuery.Substring(latitudeEnd + 1, (longitudeEnd) - (latitudeEnd + 1))); altitude = System.Double.Parse(geoURIWithoutQuery.Substring(longitudeEnd + 1)); } } catch (System.FormatException nfe) { return null; } return new GeoParsedResult(rawText.StartsWith("GEO:")?"geo:" + rawText.Substring(4):rawText, latitude, longitude, altitude); } } }