This commit is contained in:
xmd5a 2016-05-06 17:31:15 +03:00
commit 87461a3a19
11 changed files with 255 additions and 59 deletions

View file

@ -2208,4 +2208,17 @@
<string name="poi_disease_aids_no">SIDA: no</string>
<string name="poi_fire_hydrant_position_underground">Situació de l\'hidrant: soterrat</string>
<string name="poi_street_cabinet_telecom">Tipus d\'armari: telecomunicacions</string>
<string name="poi_street_cabinet_power">Tipus d\'armari: electricitat</string>
<string name="poi_street_cabinet_cable_tv">Tipus d\'armari: tv per cable</string>
<string name="poi_street_cabinet_gas">Tipus d\'armari: gas</string>
<string name="poi_street_cabinet_postal_service">Tipus d\'armari: servei postal</string>
<string name="poi_street_cabinet_waste">Tipus d\'armari: residus</string>
<string name="poi_street_cabinet_water_management">Tipus d\'armari: gestió d\'aigua</string>
<string name="poi_street_cabinet_street_lighting">Tipus d\'armari: il·luminació vial</string>
<string name="poi_health_specialty_oncology_yes">Especialitat mèdica: oncologia</string>
<string name="poi_health_specialty_tropical_medicine_yes">Especialitat mèdica:medicina tropical</string>
<string name="poi_health_specialty_tropical_medicine_no">Especialitat mèdica: sense medicina tropical</string>
<string name="poi_health_specialty_neurosurgery_yes">Especialitat mèdica: neurocirugia</string>
</resources>

View file

@ -65,7 +65,7 @@
<string name="lang_zh_CN">Ĉina (simpligita)</string>
<string name="lang_zh_TW">Ĉina (tradicia)</string>
<string name="lang_vo">Volapuko</string>
<string name="osmand_play_title_30_chars">OsmAnd Mapoj k Navigado</string>
<string name="osmand_play_title_30_chars">OsmAnd Mapoj kaj Navigado</string>
<string name="shared_string_reverse_order">Inversa ordigo</string>
<string name="switch_start_finish">Anstataŭigi komencpunkton per finpunkto</string>
<string name="rendering_attr_hideIcons_name">Piktogramoj de Interesejoj</string>
@ -495,7 +495,7 @@
<string name="rendering_attr_pisteRoutes_name">Skitrakoj</string>
<string name="free">"Libera %1$s "</string>
<string name="gps_status">GPS-a stato</string>
<string name="osmand_plus_play_title_30_chars">OsmAnd+ Mapoj k Navigado</string>
<string name="osmand_plus_play_title_30_chars">OsmAnd+ Mapoj kaj Navigado</string>
<string name="map_widget_show_ruler">Mezurilo</string>
<string name="osmand_rastermaps_plugin_description">"Per tiu ĉi kromprogramo vi povas atingi multajn enretajn (ankaŭ nomitaj kiel kahelaj aŭ rastrumaj) mapojn, ekzemple: antaŭgeneritaj OpenStreetMap kaheloj (kiel Mapnik), sputnik-fotoj kaj mapoj por specialaj uzoj: veteraj, klimataj, tersciencaj mapoj, tavoloj de nivel-ombrumo, ktp.\n\nĈiuj de tiuj mapoj oni eblas uzi kiel ĉefa (baza) mapo por OsmAnd, aŭ kiel supra aŭ malsupra tavolo por alia bazmapo (ekz. por norma OsmAnd-a eksterreta mapo). Por igi malsupran tavolon de mapo pli klaran, kelkaj elementoj de vektoraj OSM-aj mapoj oni eblas facile kaŝi uzante \'Agordi mapon\' menuon.\n\nKahelajn mapojn oni povas elŝuti senpere de interreto, aŭ prepari por eksterreta uzado (kaj permane kopii al OSM-a datum-dosierujo) kiel SQLite-a datumbazo kiu povas esti farita uzante diversajn eksterajn ilojn por prepari mapojn. "</string>
<string name="shared_string_accessibility">Alirebleco</string>
@ -540,7 +540,7 @@
<string name="download_tab_downloads">Ĉiuj</string>
<string name="download_tab_local">Lokaj</string>
<string name="no_internet_connection">Elŝutado ne eblas, bonvolu kontroli vian retkonekton.</string>
<string name="record_plugin_name">Registrado de kursoj</string>
<string name="record_plugin_name">Registrado de kurso</string>
<string name="record_plugin_description">"Tiu ĉi kromprogramo ebligas al vi registri kaj konservi viajn kursojn per permana elektado de GPX-registrada fenestraĵo sur la mapekrano, aŭ ankaŭ aŭtomate registri ĉiujn viajn navigadajn kursojn al GPX-dosiero.\n\nRegistritaj kursoj povas esti kunhavigitaj kun viaj amikoj aŭ esti uzita por kontribui la OSM-on. Atletoj povas uzi registritajn kursojn por monitori siajn ekzercojn. Kelkaj bazaj ecoj oni povas analizi senpere per OsmAnd, kiel: tempoj de ĉirkaŭoj, mezumaj rapidoj, ktp, kaj kursoj oni povas poste analizi uzante specialajn eksterajn programojn. "</string>
<string name="use_opengl_render">Uzi OpenGL-bildigon</string>
<string name="use_opengl_render_descr">Uzas aparatan plirapidigan OpenGL-bildigon (povas ne funkcii je iuj aparatoj)</string>
@ -733,7 +733,7 @@
<string name="gpx_wpt">Navigadpunkto</string>
<string name="selected_gpx_info_show">\n\nPremtrenu por vidi sur la mapo</string>
<string name="delay_navigation_start">Eki turnon post turno navigadon aŭtomate</string>
<string name="local_index_gpx_info_show">\n\nPremtrenu por montri agordojn</string>
<string name="local_index_gpx_info_show">\n\nPremtenu por montri agordojn</string>
<string name="gpx_info_waypoints">"Navigadpunktoj: %1$s "</string>
<string name="gpx_info_subtracks">"Subkursoj: %1$s "</string>
<string name="gpx_info_distance">"Distanco: %1$s (%1$s punktoj) "</string>
@ -1015,4 +1015,138 @@
<string name="local_indexes_cat_av">Sonaj/videaj datumoj</string>
<string name="stop_routing_confirm">Ĉu vi certe volas ĉesigi navigadon?</string>
<string name="clear_dest_confirm">Ĉu vi certe volas vakigi la celpunkton (kaj inter-celojn)?</string>
<string name="precise_routing_mode">Precizaj kursoj (alfa)</string>
<string name="precise_routing_mode_descr">Aktivigas kalkuladon de precizaj senerarigaj kursoj. Nuntempe ĝi estas malrapida kaj nur por limitaj distancoj.</string>
<string name="recording_context_menu_show">Montri</string>
<string name="recording_photo_description">Foto %1$s %2$s</string>
<string name="av_def_action_picture">Fari foton</string>
<string name="recording_context_menu_precord">Fari foton</string>
<string name="dropbox_plugin_description">La kromprogramo Dropbox ebligas al vi samtempigi kursojn kaj aŭdia-/videa-notojn kun via Dropbox-a konto.</string>
<string name="dropbox_plugin_name">Dropbox kromprogramo</string>
<string name="intermediate_points_change_order">Ŝanĝi ordon</string>
<string name="srtm_paid_version_msg">Bonvolu konsideri aĉeti la Nivelkurbo kromprogramo en la Market por subteni pluan disvolviĝon.</string>
<string name="av_def_action_choose">Elekti laŭvole</string>
<string name="av_def_action_video">Registri videon</string>
<string name="av_def_action_audio">Registri sonon</string>
<string name="av_widget_action_descr">Elektas implicitan agon por fenestraĵo</string>
<string name="av_widget_action">Implicita fenestraĵo ago</string>
<string name="av_video_format_descr">Elektas specon de eliga video</string>
<string name="av_video_format">Speco de eliga video</string>
<string name="av_use_external_recorder">Uzi sisteman registrilon</string>
<string name="av_use_external_recorder_descr">Uzas sisteman kameraon por videoj</string>
<string name="av_use_external_camera">Uzi sisteman fotilon</string>
<string name="av_use_external_camera_descr">Uzas sisteman aplikaĵon por fari fotojn</string>
<string name="av_settings">"Sonaj/videaj agordoj "</string>
<string name="av_settings_descr">Agordas sonon kaj videon</string>
<string name="recording_error">"Eraro okazis dum registradon "</string>
<string name="recording_camera_not_available">Fotilo ne estas alirebla</string>
<string name="recording_is_recorded">Registranta sonon/videon. Por ĉesigi premu la butonon sur la fenestraĵo.</string>
<string name="recording_playing">Ludanta sonon de elektita registraĵo.\n%1$s</string>
<string name="recording_open_external_player">Malfermi eksteran ludilon</string>
<string name="recording_delete_confirm">Ĉu vi volas forigi tiun ĉi registraĵon?</string>
<string name="recording_unavailable">nedisponebla</string>
<string name="recording_context_menu_arecord">Fari sonnoton</string>
<string name="recording_context_menu_vrecord">Fari videonoton</string>
<string name="layer_recordings">Tavolo de registrado</string>
<string name="recording_can_not_be_played">Ne povas ludi registraĵon</string>
<string name="recording_context_menu_delete">Forigi registraĵon</string>
<string name="recording_context_menu_play">Ludi</string>
<string name="recording_description">Registraĵo %1$s %3$s %2$s</string>
<string name="recording_default_name">Registraĵo</string>
<string name="map_widget_av_notes">Sonaj/videaj notoj</string>
<string name="audionotes_plugin_name">Sonaj/videaj notoj</string>
<string name="audionotes_plugin_description">La Sonaj/videaj notoj kromprogramo ebligas fari bildajn/sonajn/videajn notojn dum ekskurso, uzante aŭ butonon sur la mapekrano, aŭ senpere kuntekstan menuon por iu ajn pozicio sur la mapo.</string>
<string name="map_widget_distancemeasurement">Mezuro de distanco</string>
<string name="map_widget_audionotes">Sonaj notoj</string>
<string name="index_srtm_parts">partoj</string>
<string name="index_srtm_ele">Nivelkurboj</string>
<string name="audionotes_location_not_defined">Loko por la noto ne estas jam precizigita. \"Uzi lokon...\" por asigni noton al la difina loko</string>
<string name="download_select_map_types">Aliaj mapoj</string>
<string name="download_roads_only_item">Nur vojoj</string>
<string name="download_srtm_maps">Nivelkurboj</string>
<string name="download_regular_maps">Norma mapo</string>
<string name="download_roads_only_maps">Nur-voja mapo</string>
<string name="rendering_attr_alpineHiking_name">Montogrimpada skalo (SAC)</string>
<string name="rendering_attr_alpineHiking_description">Bildigas vojojn laŭ skalo de SAC (Svisa Alpismo-Klubo)</string>
<string name="rendering_attr_hikingRoutesOSMC_name">Piedirada tavolo</string>
<string name="rendering_attr_hikingRoutesOSMC_description">Bildigas vojojn laŭ OSMC kursoj</string>
<string name="rendering_attr_noAdminboundaries_name">Kaŝi limojn</string>
<string name="rendering_attr_noAdminboundaries_description">Ne montras regionajn limojn (administraciaj niveloj 5-9)</string>
<string name="map_widget_max_speed">Rapidlimo</string>
<string name="monitoring_control_start">GPX</string>
<string name="no_buildings_found">Nenia domo trovita.</string>
<string name="incremental_search_city">Serĉi urbon tajpante komencajn literojn</string>
<string name="search_villages_and_postcodes">Serĉi pli kamparojn/poŝtkodojn</string>
<string name="rendering_attr_showRoadMaps_name">Nur-vojaj mapoj</string>
<string name="rendering_attr_showRoadMaps_description">Elektu kiam montri nur-vojajn mapojn:</string>
<string name="safe_mode">Sendanĝera reĝimo</string>
<string name="safe_mode_description">Lanĉas la aplikaĵon en sendanĝera reĝimo (uzante pli malrapidan Androidan kodon anstataŭ indiĝenan).</string>
<string name="native_library_not_running">La aplikaĵo funkcias en sendanĝera reĝimo (malaktivigi ĝin en agordoj).</string>
<string name="close_changeset">Fermi ŝanĝaron</string>
<string name="zxing_barcode_scanner_not_found">ZXing Barcode Scanner ne estas instalita. Ĉu serĉi ĝin en Google Play?</string>
<string name="rendering_attr_roadColors_description">Elektu skemkoloron de vojoj:</string>
<string name="rendering_attr_roadColors_name">Skemkoloro de vojoj</string>
<string name="map_widget_show_destination_arrow">Montri celdirekton</string>
<string name="enable_plugin_monitoring_services">Aktivigu la Registrado de kurso kromprogramo por uzi pozicio-registradajn servojn (GPX-registrado, enreta kurs-registrado)</string>
<string name="non_optimal_route_calculation">Kalkuli verŝajne ne-plejbonajn kursojn por malproksimaj distancoj</string>
<string name="gps_not_available">Bonvolu aktivigi GPS-on en agordoj</string>
<string name="map_widget_monitoring_services">Kurso-registradaj servoj</string>
<string name="no_route">Nenia kurso</string>
<string name="delete_target_point">Forigi celon</string>
<string name="target_point">Celo %1$s</string>
<string name="intermediate_point">Inter-celo %1$s</string>
<string name="context_menu_item_last_intermediate_point">Aldoni kiel fina inter-celo</string>
<string name="context_menu_item_first_intermediate_point">Aldoni kiel unua inter-celo</string>
<string name="add_as_last_destination_point">Aldoni kiel fina inter-celo</string>
<string name="add_as_first_destination_point">Aldoni kiel unua inter-celo</string>
<string name="replace_destination_point">Anstataŭigi celon</string>
<string name="new_destination_point_dialog">Vi jam elektis celpunkton.</string>
<string name="target_points">Celoj</string>
<string name="intermediate_point_too_far">Inter-celo %1$s estas tro malproksime al la plej proksima vojo.</string>
<string name="arrived_at_intermediate_point">Vi alvenis al la inter-celo</string>
<string name="context_menu_item_intermediate_point">Aldoni kiel inter-celo</string>
<string name="map_widget_intermediate_distance">Inter-celo</string>
<string name="ending_point_too_far">Celo estas tro malproksime al la plej proksima vojo.</string>
<string name="add_tag">Aldoni markon</string>
<string name="btn_advanced_mode">Sperta reĝimo…</string>
<string name="poi_filter_parking">Parkumejo</string>
<string name="poi_filter_emergency">ISS (Integra savsistemo)</string>
<string name="poi_filter_public_transport">Transporto publika</string>
<string name="poi_filter_entertainment">Amuzaĵoj</string>
<string name="poi_filter_accomodation">Loĝado</string>
<string name="poi_filter_restaurants">Manĝejoj</string>
<string name="poi_filter_sightseeing">Vidintaĵoj</string>
<string name="poi_filter_car_aid">Aŭto-helpo</string>
<string name="poi_filter_food_shop">Manĝovendejo</string>
<string name="poi_filter_for_tourists">Por turistoj</string>
<string name="poi_filter_fuel">Brulaĵo</string>
<string name="show_warnings_title">Montri avertojn…</string>
<string name="show_warnings_descr">Agordas trafikajn avertojn (pri rapidlimoj, endaj haltejoj, strat-ĝiboj), avertojn pri rapid-kontroladoj, kaj informojn pri koridoroj</string>
<string name="use_compass_navigation">Uzi kompason</string>
<string name="use_compass_navigation_descr">Uzas kompason, nur kiam nenia direkto estas legebla</string>
<string name="avoid_motorway">Eviti aŭtovojojn</string>
<string name="auto_zoom_map">Aŭtomate skaladi mapon</string>
<string name="auto_zoom_map_descr">Aŭtomate skaladi mapon depende de via rapido (dum mapo estas samtempigita kun aktuala pozicio)</string>
<string name="snap_to_road_descr">Proksimumigas pozicion al vojo dum navigado</string>
<string name="snap_to_road">Proksimumigi al vojo</string>
<string name="interrupt_music">Paŭzi muzikon</string>
<string name="interrupt_music_descr">Paŭzas muzikon dum sciigoj</string>
<string name="osmand_short_description_80_chars">Foliumi tutmondajn mapojn kaj navigadi uzante eksterretajn kaj enretajn OSM mapojn</string>
<string name="osmand_plus_short_description_80_chars">Foliumi tutmondajn mapojn kaj navigadi uzante eksterretajn kaj enretajn OSM mapojn</string>
<string name="osmand_long_description_1000_chars">" OsmAnd (OSM Aŭtomata Navigado Direktanta al la celo) OsmAnd estas malfermkoda navigada aplikaĵo subtenanta diversajn mondajn mapojn de OpenStreetMap (OSM). Ĉiuj mapoj (vektoraj kaj kahelaj) povas esti konservita en la poŝtelefona memorejo por eksterreta uzado. OsmAnd ankaŭ ebligas uzi eksterretan kaj enretan navigadon kun turnon post turno voĉaj anoncoj.\nĈefaj eblecoj:\n - Funkcias tute eksterrete (konservas elŝutitajn vektorajn aŭ kahelaj mapojn en la aparata memorejo)\n - Kompaktaj vektoraj eksterretaj mapoj de la tuta mondo\n - Elŝuti landaj aŭ regionaj mapoj senpere en la aplikaĵo\n - Diversspecaj tavoloj de mapo: GPX aŭ navigadaj kursoj, Interesejoj, ŝatataj ejoj, nivelkurboj publiktransportaj haltejoj, ekstraj mapoj kun ŝanĝebla diafaneco\n - Serĉi eksterrete adresojn kaj interesajn ejojn (Interesejojn)\n - Difini kursojn por mallongaj distancoj eksterrete (iafoje malfunkcias)\n - Aŭta, bicikla, kaj perpiedanta reĝimoj kun:\n - agordebla aŭtomata/taga/nokta aspekto\n - agordebla rapid-dependa map-skalado\n - agordebla map-turniĝo laŭ direkto de movado aŭ kompaso\n - sciigoj pri koridoroj, rapidlimoj, antaŭregistritaj aŭ sintezitaj parolaj helpoj\nLimoj en tiu ĉi senpaga versio de OsmAnd:\n - Limita nombro da elŝutoj de mapoj\n - Sen aliro al eksterretaj Vikipediaj Interesejoj\nOsmAnd estas konstante disvolviĝanta kaj ĝia plua disvolviĝo dependas de monaj donacoj por subteni programadon kaj testadon de novaj eblecoj. Bonvolu konsideri aĉeti na OsmAnd+, aŭ donaci por aŭ elektitaj funkcioj aŭ ĝenerale por la projekto je osmand.net. "</string>
<string name="day_night_info_description">Sunleviĝo: %1$s\nSunsubiro: %2$s</string>
<string name="day_night_info">Informo pri tago/nokto</string>
<string name="filterpoi_activity">Krei Interesejan filtrilon</string>
<string name="recalculate_route_to_your_location">Transporta speco:</string>
<string name="select_navigation_mode">Elektas manieron de movado</string>
<string name="layer_map_appearance">Agordi ekranon</string>
<string name="map_widget_renderer">Map-aspekto</string>
<string name="show_lanes">Montri koridorojn</string>
<string name="avoid_unpaved">Eviti tervojojn</string>
<string name="avoid_ferries">Eviti pramojn</string>
<string name="avoid_in_routing_title">Eviti…</string>
<string name="avoid_in_routing_descr">Evitas pagendajn vojojn, tervojojn, pramojn</string>
<string name="map_widget_fluorescent">Rebrilaj kursoj</string>
</resources>

View file

@ -1899,9 +1899,9 @@
<string name="poi_surface_paved">Superficie pavimentada</string>
<string name="poi_surface_asphalt">Superficie asfaltada</string>
<string name="poi_surface_concrete">Superficie de hormigón</string>
<string name="poi_surface_sett">Superficie adoquinada</string>
<string name="poi_surface_sett">Superficie de pavimento intertrabado</string>
<string name="poi_surface_cobblestone">Superficie empedrada (adoquín)</string>
<string name="poi_surface_paving_stones">Superficie de adoquín prefabricado</string>
<string name="poi_surface_paving_stones">Superficie de adoquín prefabricado (loseta)</string>
<string name="poi_surface_pebblestone">Superficie empedrada (canto rodado)</string>
<string name="poi_surface_stone">Superficie de piedras</string>
<string name="poi_surface_metal">Superficie metalizada</string>

View file

@ -1757,9 +1757,9 @@
<string name="poi_surface_paved">Superficie pavimentada</string>
<string name="poi_surface_asphalt">Superficie asfaltada</string>
<string name="poi_surface_concrete">Superficie de hormigón</string>
<string name="poi_surface_sett">Superficie adoquinada</string>
<string name="poi_surface_sett">Superficie de pavimento intertrabado</string>
<string name="poi_surface_cobblestone">Superficie empedrada (adoquín)</string>
<string name="poi_surface_paving_stones">Superficie de adoquín prefabricado</string>
<string name="poi_surface_paving_stones">Superficie de adoquín prefabricado (loseta)</string>
<string name="poi_surface_pebblestone">Superficie empedrada (canto rodado)</string>
<string name="poi_surface_stone">Superficie de piedras</string>
<string name="poi_surface_metal">Superficie metalizada</string>

File diff suppressed because one or more lines are too long

View file

@ -2184,4 +2184,6 @@
<string name="follow_us">追蹤我們</string>
<string name="access_direction_audio_feedback">方向音訊反饋</string>
<string name="access_direction_audio_feedback_descr">用聲音指示目標點方向</string>
<string name="access_direction_haptic_feedback">方向觸感反饋</string>
<string name="access_direction_haptic_feedback_descr">由振動指示目標點方向</string>
</resources>

View file

@ -169,7 +169,7 @@
<color name="nav_arrow_distant">#C0C0C0</color>
<color name="nav_arrow">#FADE23</color>
<color name="nav_arrow_imminent">#ff8800</color>
<color name="nav_arrow_imminent">#2EFF00</color>
<color name="nav_point">#FA5050</color>
<color name="poi_background">#A0FF8000</color>

View file

@ -261,18 +261,18 @@ public class MapActivityLayers {
}
public void showMultichoicePoiFilterDialog(final OsmandMapTileView mapView, final ConfirmListener listener) {
public void showMultichoicePoiFilterDialog(final OsmandMapTileView mapView, final DismissListener listener) {
final OsmandApplication app = getApplication();
final PoiFiltersHelper poiFilters = app.getPoiFilters();
final ContextMenuAdapter adapter = new ContextMenuAdapter();
final List<PoiUIFilter> list = new ArrayList<>();
list.add(poiFilters.getCustomPOIFilter());
for (PoiUIFilter f : poiFilters.getTopDefinedPoiFilters()) {
addFilterToList(adapter, list, f, true);
}
for (PoiUIFilter f : poiFilters.getSearchPoiFilters()) {
addFilterToList(adapter, list, f, true);
}
list.add(poiFilters.getCustomPOIFilter());
final ArrayAdapter<ContextMenuItem> listAdapter = adapter.createListAdapter(activity, app.getSettings().isLightContent());
AlertDialog.Builder builder = new AlertDialog.Builder(activity);
@ -294,8 +294,16 @@ public class MapActivityLayers {
.setPositiveButton(R.string.shared_string_ok, new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
for (int i = 0; i < listAdapter.getCount(); i++) {
ContextMenuItem item = listAdapter.getItem(i);
PoiUIFilter filter = list.get(i);
if (item.getSelected()) {
getApplication().getPoiFilters().addSelectedPoiFilter(filter);
} else {
getApplication().getPoiFilters().removeSelectedPoiFilter(filter);
}
}
mapView.refreshMap();
listener.confirm();
}
})
.setNegativeButton(R.string.shared_string_cancel, null)
@ -312,15 +320,25 @@ public class MapActivityLayers {
public void onShow(DialogInterface dialog) {
Button neutralButton = alertDialog.getButton(DialogInterface.BUTTON_NEUTRAL);
Drawable drawable = app.getIconsCache().getThemedIcon(R.drawable.ic_action_singleselect);
neutralButton.setCompoundDrawablesWithIntrinsicBounds(drawable, null, null, null); }
neutralButton.setCompoundDrawablesWithIntrinsicBounds(drawable, null, null, null);
}
});
alertDialog.setOnDismissListener(new DialogInterface.OnDismissListener() {
@Override
public void onDismiss(DialogInterface dialog) {
listener.dismiss();
}
});
alertDialog.show();
}
public void showSingleChoicePoiFilterDialog(final OsmandMapTileView mapView, final ConfirmListener listener) {
public void showSingleChoicePoiFilterDialog(final OsmandMapTileView mapView, final DismissListener listener) {
final OsmandApplication app = getApplication();
final PoiFiltersHelper poiFilters = app.getPoiFilters();
final ContextMenuAdapter adapter = new ContextMenuAdapter();
adapter.addItem(new ContextMenuItem.ItemBuilder()
.setTitleId(R.string.shared_string_search, app)
.setIcon(R.drawable.ic_action_search_dark).createItem());
final List<PoiUIFilter> list = new ArrayList<>();
list.add(poiFilters.getCustomPOIFilter());
for (PoiUIFilter f : poiFilters.getTopDefinedPoiFilters()) {
@ -336,7 +354,7 @@ public class MapActivityLayers {
builder.setAdapter(listAdapter, new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
PoiUIFilter pf = list.get(which + 1);
PoiUIFilter pf = list.get(which);
String filterId = pf.getFilterId();
if (filterId.equals(PoiUIFilter.CUSTOM_FILTER_ID)) {
Intent search = new Intent(activity, SearchActivity.class);
@ -347,13 +365,12 @@ public class MapActivityLayers {
getApplication().getPoiFilters().clearSelectedPoiFilters();
getApplication().getPoiFilters().addSelectedPoiFilter(pf);
mapView.refreshMap();
listener.confirm();
}
}
});
builder.setTitle(R.string.show_poi_over_map);
builder.setNegativeButton(R.string.shared_string_cancel, null);
builder.setNegativeButton(R.string.shared_string_dismiss, null);
builder.setNeutralButton(" ", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
@ -366,7 +383,14 @@ public class MapActivityLayers {
public void onShow(DialogInterface dialog) {
Button neutralButton = alertDialog.getButton(DialogInterface.BUTTON_NEUTRAL);
Drawable drawable = app.getIconsCache().getThemedIcon(R.drawable.ic_action_multiselect);
neutralButton.setCompoundDrawablesWithIntrinsicBounds(drawable, null, null, null); }
neutralButton.setCompoundDrawablesWithIntrinsicBounds(drawable, null, null, null);
}
});
alertDialog.setOnDismissListener(new DialogInterface.OnDismissListener() {
@Override
public void onDismiss(DialogInterface dialog) {
listener.dismiss();
}
});
alertDialog.show();
}
@ -378,18 +402,16 @@ public class MapActivityLayers {
list.add(f);
ContextMenuItem.ItemBuilder builder = new ContextMenuItem.ItemBuilder();
if (multichoice) {
builder.setSelected(getApplication().getPoiFilters().isPoiFilterSelected(f));
builder.setListener(new ContextMenuAdapter.ItemClickListener() {
@Override
public boolean onContextMenuClick(ArrayAdapter<ContextMenuItem> adapter, int itemId, int position, boolean isChecked) {
if (isChecked) {
getApplication().getPoiFilters().addSelectedPoiFilter(f);
} else {
getApplication().getPoiFilters().removeSelectedPoiFilter(f);
}
return true;
public boolean onContextMenuClick(ArrayAdapter<ContextMenuItem> adapter,
int itemId, int position, boolean isChecked) {
ContextMenuItem item = adapter.getItem(position);
item.setSelected(isChecked);
return false;
}
});
builder.setSelected(getApplication().getPoiFilters().isPoiFilterSelected(f));
}
builder.setTitle(f.getName());
if (RenderingIcons.containsBigIcon(f.getIconId())) {
@ -586,7 +608,7 @@ public class MapActivityLayers {
return downloadedRegionsLayer;
}
public interface ConfirmListener {
void confirm();
public interface DismissListener {
void dismiss();
}
}

View file

@ -125,18 +125,18 @@ public class ConfigureMapMenu {
@Override
public boolean onContextMenuClick(final ArrayAdapter<ContextMenuItem> adapter, int itemId, final int pos, boolean isChecked) {
final OsmandSettings settings = ma.getMyApplication().getSettings();
final PoiFiltersHelper pfh = ma.getMyApplication().getPoiFilters();
final PoiFiltersHelper poiFiltersHelper = ma.getMyApplication().getPoiFilters();
final ContextMenuItem item = cm.getItem(pos);
if (item.getSelected() != null) {
item.setColorRes(isChecked ? R.color.osmand_orange : ContextMenuItem.INVALID_ID);
adapter.notifyDataSetChanged();
}
if (itemId == R.string.layer_poi) {
pfh.clearSelectedPoiFilters();
poiFiltersHelper.clearSelectedPoiFilters();
if (isChecked) {
showPoiFilterDialog(adapter, adapter.getItem(pos));
} else {
adapter.getItem(pos).setDescription(pfh.getSelectedPoiFiltersName());
adapter.getItem(pos).setDescription(poiFiltersHelper.getSelectedPoiFiltersName());
}
} else if (itemId == R.string.layer_amenity_label) {
settings.SHOW_POI_LABEL.set(isChecked);
@ -185,18 +185,26 @@ public class ConfigureMapMenu {
protected void showPoiFilterDialog(final ArrayAdapter<ContextMenuItem> adapter,
final ContextMenuItem item) {
ma.getMapLayers().showSingleChoicePoiFilterDialog(ma.getMapView(),
new MapActivityLayers.ConfirmListener() {
@Override
public void confirm() {
PoiFiltersHelper pf = ma.getMyApplication().getPoiFilters();
boolean selected = pf.isShowingAnyPoi();
item.setSelected(selected);
item.setDescription(pf.getSelectedPoiFiltersName());
item.setColorRes(selected ? R.color.osmand_orange : ContextMenuItem.INVALID_ID);
adapter.notifyDataSetChanged();
}
});
final PoiFiltersHelper poiFiltersHelper = ma.getMyApplication().getPoiFilters();
MapActivityLayers.DismissListener dismissListener =
new MapActivityLayers.DismissListener() {
@Override
public void dismiss() {
PoiFiltersHelper pf = ma.getMyApplication().getPoiFilters();
boolean selected = pf.isShowingAnyPoi();
item.setSelected(selected);
item.setDescription(pf.getSelectedPoiFiltersName());
item.setColorRes(selected ? R.color.osmand_orange : ContextMenuItem.INVALID_ID);
adapter.notifyDataSetChanged();
}
};
if (poiFiltersHelper.getSelectedPoiFilters().size() > 1) {
ma.getMapLayers().showMultichoicePoiFilterDialog(ma.getMapView(),
dismissListener);
} else {
ma.getMapLayers().showSingleChoicePoiFilterDialog(ma.getMapView(),
dismissListener);
}
}
}

View file

@ -618,9 +618,9 @@ public class WaypointDialogHelper {
thisAdapter.notifyDataSetInvalidated();
MapActivity map = (MapActivity) ctx;
map.getMapLayers().showSingleChoicePoiFilterDialog(map.getMapView(),
new MapActivityLayers.ConfirmListener() {
new MapActivityLayers.DismissListener() {
@Override
public void confirm() {
public void dismiss() {
enableType(running, thisAdapter, type, true);
}
});
@ -692,9 +692,9 @@ public class WaypointDialogHelper {
!app.getPoiFilters().isPoiFilterSelected(PoiUIFilter.CUSTOM_FILTER_ID)) {
MapActivity map = (MapActivity) ctx;
map.getMapLayers().showSingleChoicePoiFilterDialog(map.getMapView(),
new MapActivityLayers.ConfirmListener() {
new MapActivityLayers.DismissListener() {
@Override
public void confirm() {
public void dismiss() {
if (app.getPoiFilters().isShowingAnyPoi()) {
enableType(running, listAdapter, type, enable);
}

View file

@ -321,7 +321,7 @@ public class TurnPathHelper {
}
}
private static TurnResource getTallArrow(int tt){
private static TurnResource getTallArrow(int tt, boolean nooverlap){
TurnResource result = new TurnResource();
@ -331,7 +331,7 @@ public class TurnPathHelper {
break;
case TurnType.TR:
case TurnType.TL:
result.resourceId = R.drawable.map_turn_right2_small;
result.resourceId = nooverlap ? R.drawable.map_turn_right_small : R.drawable.map_turn_right2_small;
break;
case TurnType.KR:
case TurnType.KL:
@ -416,14 +416,14 @@ public class TurnPathHelper {
if (turnIndex == FIRST_TURN) {
if (secondTurnType == 0) {
turnResource = getTallArrow(firstTurnType);
turnResource = getTallArrow(firstTurnType, true);
} else if (secondTurnType == TurnType.C || thirdTurnType == TurnType.C) {
turnResource = getShortArrow(firstTurnType);
} else {
if (firstTurnType == TurnType.TU || firstTurnType == TurnType.TRU) {
turnResource = getShortArrow(firstTurnType);
} else {
turnResource = getTallArrow(firstTurnType);
turnResource = getTallArrow(firstTurnType, false);
}
}
} else if (turnIndex == SECOND_TURN) {
@ -435,7 +435,7 @@ public class TurnPathHelper {
// get the small one
turnResource = getShortArrow(secondTurnType);
} else {
turnResource = getTallArrow(secondTurnType);
turnResource = getTallArrow(secondTurnType, false);
}
} else if (turnIndex == THIRD_TURN) {
if ((TurnType.isLeftTurn(firstTurnType) || TurnType.isLeftTurn(secondTurnType)) && TurnType.isLeftTurn(thirdTurnType)) {