19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/*
29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2007, The Android Open Source Project
39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License.
69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at
79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *     http://www.apache.org/licenses/LICENSE-2.0
99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and
149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License.
159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.location;
189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.app.PendingIntent;
209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.location.Address;
2103ca216ac19ea4e7afcb183c20c7c780f0d97756Mike Lockwoodimport android.location.Criteria;
2234901409a404c8c66914c5a8ad0f29b1bcde0e78Mike Lockwoodimport android.location.GeocoderParams;
23a55c321329ae52a2db7a4f2bd36673a20b8f271dMike Lockwoodimport android.location.IGeocodeProvider;
249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.location.IGpsStatusListener;
259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.location.ILocationListener;
269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.location.Location;
279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.Bundle;
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * System private API for talking with the location service.
319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@hide}
339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectinterface ILocationManager
359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{
3603ca216ac19ea4e7afcb183c20c7c780f0d97756Mike Lockwood    List<String> getAllProviders();
3703ca216ac19ea4e7afcb183c20c7c780f0d97756Mike Lockwood    List<String> getProviders(in Criteria criteria, boolean enabledOnly);
3803ca216ac19ea4e7afcb183c20c7c780f0d97756Mike Lockwood    String getBestProvider(in Criteria criteria, boolean enabledOnly);
3903ca216ac19ea4e7afcb183c20c7c780f0d97756Mike Lockwood    boolean providerMeetsCriteria(String provider, in Criteria criteria);
409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4103ca216ac19ea4e7afcb183c20c7c780f0d97756Mike Lockwood    void requestLocationUpdates(String provider, in Criteria criteria, long minTime, float minDistance,
4203ca216ac19ea4e7afcb183c20c7c780f0d97756Mike Lockwood        boolean singleShot, in ILocationListener listener);
4303ca216ac19ea4e7afcb183c20c7c780f0d97756Mike Lockwood    void requestLocationUpdatesPI(String provider, in Criteria criteria, long minTime, float minDistance,
4403ca216ac19ea4e7afcb183c20c7c780f0d97756Mike Lockwood        boolean singleShot, in PendingIntent intent);
459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void removeUpdates(in ILocationListener listener);
469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void removeUpdatesPI(in PendingIntent intent);
479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    boolean addGpsStatusListener(IGpsStatusListener listener);
499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void removeGpsStatusListener(IGpsStatusListener listener);
5048f17518223a2917fd82195004fbb206cb9a05a3Mike Lockwood
5148f17518223a2917fd82195004fbb206cb9a05a3Mike Lockwood    // for reporting callback completion
5248f17518223a2917fd82195004fbb206cb9a05a3Mike Lockwood    void locationCallbackFinished(ILocationListener listener);
5348f17518223a2917fd82195004fbb206cb9a05a3Mike Lockwood
549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    boolean sendExtraCommand(String provider, String command, inout Bundle extras);
559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void addProximityAlert(double latitude, double longitude, float distance,
579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        long expiration, in PendingIntent intent);
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void removeProximityAlert(in PendingIntent intent);
599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    Bundle getProviderInfo(String provider);
619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    boolean isProviderEnabled(String provider);
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    Location getLastKnownLocation(String provider);
64275555c8eb3fb5df6e7320873b88b77cdde85a9eMike Lockwood
65a4903f254b4711c8fc0ac5f7e3d605f4dce34f35Mike Lockwood    // Used by location providers to tell the location manager when it has a new location.
66a4903f254b4711c8fc0ac5f7e3d605f4dce34f35Mike Lockwood    // Passive is true if the location is coming from the passive provider, in which case
67a4903f254b4711c8fc0ac5f7e3d605f4dce34f35Mike Lockwood    // it need not be shared with other providers.
68a4903f254b4711c8fc0ac5f7e3d605f4dce34f35Mike Lockwood    void reportLocation(in Location location, boolean passive);
699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
70e15735a9e0c0b1448b68f2d6b3247404fc1df417Mike Lockwood    boolean geocoderIsPresent();
719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    String getFromLocation(double latitude, double longitude, int maxResults,
7234901409a404c8c66914c5a8ad0f29b1bcde0e78Mike Lockwood        in GeocoderParams params, out List<Address> addrs);
739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    String getFromLocationName(String locationName,
749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        double lowerLeftLatitude, double lowerLeftLongitude,
759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        double upperRightLatitude, double upperRightLongitude, int maxResults,
7634901409a404c8c66914c5a8ad0f29b1bcde0e78Mike Lockwood        in GeocoderParams params, out List<Address> addrs);
779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void addTestProvider(String name, boolean requiresNetwork, boolean requiresSatellite,
799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        boolean requiresCell, boolean hasMonetaryCost, boolean supportsAltitude,
809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        boolean supportsSpeed, boolean supportsBearing, int powerRequirement, int accuracy);
819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void removeTestProvider(String provider);
829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void setTestProviderLocation(String provider, in Location loc);
839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void clearTestProviderLocation(String provider);
849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void setTestProviderEnabled(String provider, boolean enabled);
859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void clearTestProviderEnabled(String provider);
869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void setTestProviderStatus(String provider, int status, in Bundle extras, long updateTime);
879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void clearTestProviderStatus(String provider);
88e932f7f2a47b770c636443d411436bd29cc4bb43Mike Lockwood
8922d1f9fb23015471de6af1a70e40fb5c82ecb665Danke Xie    // for NI support
9022d1f9fb23015471de6af1a70e40fb5c82ecb665Danke Xie    boolean sendNiResponse(int notifId, int userResponse);
919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
92