Compare commits
2 Commits
release/20
...
pastk-mapg
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5a7c466483 | ||
|
|
0176b63ae3 |
@@ -1,4 +1,4 @@
|
||||
name: Android Check Store Metadata
|
||||
name: Android Check Metadata
|
||||
on:
|
||||
workflow_dispatch: # Manual trigger
|
||||
pull_request:
|
||||
@@ -21,8 +21,5 @@ jobs:
|
||||
android
|
||||
tools/python/check_store_metadata.py
|
||||
|
||||
- name: Check Google Play metadata
|
||||
run: ./tools/python/check_store_metadata.py gplay
|
||||
|
||||
- name: Check F-Droid metadata
|
||||
run: ./tools/python/check_store_metadata.py fdroid
|
||||
- name: Check metadata
|
||||
run: ./tools/python/check_store_metadata.py android
|
||||
|
||||
@@ -8,19 +8,21 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
environment: production
|
||||
steps:
|
||||
- name: Checkout
|
||||
- name: Checkout sources
|
||||
# TODO: use shallow (and sparse?) checkout
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 1
|
||||
sparse-checkout: |
|
||||
android
|
||||
tools/python/check_store_metadata.py
|
||||
|
||||
# - name: Parallel submodules checkout
|
||||
# shell: bash
|
||||
# run: git submodule update --depth 1 --init --recursive --jobs=$(($(nproc) * 20))
|
||||
|
||||
- name: Restore release keys
|
||||
shell: bash
|
||||
run: |
|
||||
echo "$PRIVATE_H" | base64 -d > private.h
|
||||
echo "$GOOGLE_PLAY_JSON" | base64 -d > android/app/google-play.json
|
||||
env:
|
||||
PRIVATE_H: ${{ secrets.PRIVATE_H }}
|
||||
GOOGLE_PLAY_JSON: ${{ secrets.GOOGLE_PLAY_JSON }}
|
||||
|
||||
- name: Upload
|
||||
|
||||
@@ -35,7 +35,7 @@ jobs:
|
||||
name: Apple TestFlight
|
||||
runs-on: macos-15
|
||||
env:
|
||||
DEVELOPER_DIR: /Applications/Xcode_26.app/Contents/Developer
|
||||
DEVELOPER_DIR: /Applications/Xcode_16.app/Contents/Developer
|
||||
LANG: en_US.UTF-8 # Fastlane complains that the terminal is using ASCII.
|
||||
LANGUAGE: en_US.UTF-8
|
||||
LC_ALL: en_US.UTF-8
|
||||
|
||||
@@ -37,7 +37,7 @@ jobs:
|
||||
name: Build iOS
|
||||
runs-on: macos-15
|
||||
env:
|
||||
DEVELOPER_DIR: /Applications/Xcode_26.app/Contents/Developer
|
||||
DEVELOPER_DIR: /Applications/Xcode_16.app/Contents/Developer
|
||||
LANG: en_US.UTF-8 # Fastlane complains that the terminal is using ASCII.
|
||||
LANGUAGE: en_US.UTF-8
|
||||
LC_ALL: en_US.UTF-8
|
||||
|
||||
@@ -7,7 +7,7 @@ jobs:
|
||||
name: iOS Release
|
||||
runs-on: macos-15
|
||||
env:
|
||||
DEVELOPER_DIR: /Applications/Xcode_26.app/Contents/Developer
|
||||
DEVELOPER_DIR: /Applications/Xcode_16.app/Contents/Developer
|
||||
LANG: en_US.UTF-8 # Fastlane complains that the terminal is using ASCII.
|
||||
LANGUAGE: en_US.UTF-8
|
||||
LC_ALL: en_US.UTF-8
|
||||
|
||||
@@ -32,7 +32,7 @@ jobs:
|
||||
name: macOS builds and tests
|
||||
runs-on: macos-15
|
||||
env:
|
||||
DEVELOPER_DIR: /Applications/Xcode_26.app/Contents/Developer
|
||||
DEVELOPER_DIR: /Applications/Xcode_16.app/Contents/Developer
|
||||
HOMEBREW_NO_ANALYTICS: 1
|
||||
HOMEBREW_NO_INSTALL_CLEANUP: 1
|
||||
strategy:
|
||||
|
||||
22
.forgejo/workflows/stale.yml
Normal file
@@ -0,0 +1,22 @@
|
||||
name: Close stale PRs
|
||||
on:
|
||||
schedule:
|
||||
- cron: "0 0 * * *" # Runs every day at midnight
|
||||
|
||||
jobs:
|
||||
stale:
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
pull-requests: write
|
||||
steps:
|
||||
- uses: actions/stale@v9
|
||||
with:
|
||||
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
||||
days-before-pr-stale: 180 # 6 months before warning
|
||||
days-before-pr-close: 365 # Closed after 12 months
|
||||
stale-pr-label: "stale"
|
||||
stale-pr-message: "Hi! This PR has been inactive for 6 months. If it's still relevant, please update it to let us know you’d like to keep it open 😊"
|
||||
close-pr-message: "This PR has been automatically closed after 12 months of inactivity."
|
||||
days-before-issue-stale: -1 # Issues are never stale
|
||||
days-before-issue-close: -1 # Issues are never closed
|
||||
remove-stale-when-updated: true
|
||||
12
.github/workflows/android-check.yaml
vendored
@@ -23,16 +23,9 @@ jobs:
|
||||
shell: bash
|
||||
run: git submodule update --depth 1 --init --recursive --jobs=$(($(nproc) * 20))
|
||||
|
||||
- name: Install protobuf
|
||||
shell: bash
|
||||
run: |
|
||||
sudo apt-get update -y
|
||||
sudo apt-get install -y python3-pip
|
||||
pip install "protobuf<3.21" --break-system-packages
|
||||
|
||||
- name: Configure repository
|
||||
shell: bash
|
||||
run: ./configure.sh
|
||||
run: SKIP_GENERATE_SYMBOLS=1 ./configure.sh
|
||||
|
||||
- name: Lint
|
||||
shell: bash
|
||||
@@ -73,9 +66,8 @@ jobs:
|
||||
libxinerama-dev \
|
||||
libxcursor-dev \
|
||||
libxi-dev \
|
||||
python3-pip \
|
||||
python3-protobuf \
|
||||
zlib1g-dev
|
||||
pip install "protobuf<3.21" --break-system-packages
|
||||
|
||||
- name: Checkout sources
|
||||
uses: actions/checkout@v4
|
||||
|
||||
2
.github/workflows/ios-check.yaml
vendored
@@ -10,7 +10,7 @@ jobs:
|
||||
name: Build iOS
|
||||
runs-on: macos-15
|
||||
env:
|
||||
DEVELOPER_DIR: /Applications/Xcode_26.app/Contents/Developer
|
||||
DEVELOPER_DIR: /Applications/Xcode_16.app/Contents/Developer
|
||||
LANG: en_US.UTF-8 # Fastlane complains that the terminal is using ASCII.
|
||||
LANGUAGE: en_US.UTF-8
|
||||
LC_ALL: en_US.UTF-8
|
||||
|
||||
3
.gitignore
vendored
@@ -35,9 +35,6 @@ data/patterns.txt*
|
||||
# data/colors_design.txt
|
||||
# data/patterns_design.txt
|
||||
|
||||
# Auto-generated from data/categories-strings/* by tools/unix/generate_categories.sh
|
||||
data/categories.txt
|
||||
|
||||
# Compiled Python
|
||||
*.pyc
|
||||
|
||||
|
||||
@@ -225,26 +225,6 @@ endif()
|
||||
# Used in qt/ and shaders/
|
||||
find_package(Python3 REQUIRED COMPONENTS Interpreter)
|
||||
|
||||
execute_process(
|
||||
COMMAND ${Python3_EXECUTABLE} -c "import google.protobuf;
|
||||
print(google.protobuf.__version__)"
|
||||
RESULT_VARIABLE PROTOBUF_CHECK
|
||||
OUTPUT_VARIABLE PROTOBUF_VERSION
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||
ERROR_QUIET
|
||||
)
|
||||
|
||||
if(PROTOBUF_CHECK EQUAL 0)
|
||||
if(PROTOBUF_VERSION VERSION_LESS "4.0.0")
|
||||
message(STATUS "Python protobuf ${PROTOBUF_VERSION} found (< 4.0)")
|
||||
else()
|
||||
message(FATAL_ERROR "Python protobuf ${PROTOBUF_VERSION} found, but version < 4.0 required")
|
||||
endif()
|
||||
else()
|
||||
message(FATAL_ERROR "Python protobuf not found. Install version <4.0")
|
||||
endif()
|
||||
|
||||
|
||||
add_subdirectory(libs)
|
||||
|
||||
if (PLATFORM_DESKTOP)
|
||||
|
||||
@@ -51,9 +51,6 @@ A community-led free & open source maps app based on [OpenStreetMap](https://www
|
||||
<a href="https://f-droid.org/en/packages/app.comaps.fdroid/">
|
||||
<img src="docs/badges/fdroid.png" alt="F-Droid" width="160"/>
|
||||
</a>
|
||||
<a href="https://apt.izzysoft.de/fdroid/index/apk/app.comaps">
|
||||
<img src="docs/badges/izzyondroid.png" alt="Obtainium" width="160"/>
|
||||
</a>
|
||||
<a href="https://apps.obtainium.imranr.dev/redirect?r=obtainium://add/https://codeberg.org/comaps/comaps">
|
||||
<img src="docs/badges/obtainium.png" alt="Obtainium" width="160"/>
|
||||
</a>
|
||||
@@ -158,12 +155,6 @@ SHA-256: 4894e8e6963627ef660031d8593fe77297f835acb4e23810003e926135023b4c
|
||||
SHA-1: 8b7b5739f917e9f7c681671ced0c9c8562123ade
|
||||
MD5: 9cce0ffea281dc2f0e0a154d6d2e281e
|
||||
```
|
||||
|
||||
To verify CoMaps via [AppVerifier](https://github.com/soupslurpr/AppVerifier), use the following signing certificate fingerprint:
|
||||
```
|
||||
app.comaps
|
||||
48:94:E8:E6:96:36:27:EF:66:00:31:D8:59:3F:E7:72:97:F8:35:AC:B4:E2:38:10:00:3E:92:61:35:02:3B:4C
|
||||
```
|
||||
---
|
||||
|
||||
## ⚖️ License
|
||||
|
||||
3
android/app/.gitignore
vendored
@@ -24,6 +24,3 @@
|
||||
/src/main/res/drawable-mdpi/uk_northern_ireland.png
|
||||
/src/main/res/drawable-mdpi/uk_scotland.png
|
||||
/src/main/res/drawable-mdpi/uk_wales.png
|
||||
|
||||
# Symlinked to F-Droid relnotes by tools/unix/link_gplay_relnotes.sh
|
||||
/src/google/play/release-notes
|
||||
@@ -355,7 +355,8 @@ dependencies {
|
||||
// Fix for app/organicmaps/util/FileUploadWorker.java:14: error: cannot access ListenableFuture
|
||||
// https://github.com/organicmaps/organicmaps/issues/6106
|
||||
implementation libs.google.guava
|
||||
implementation libs.appdevnext.androidchart
|
||||
implementation libs.devnullorthrow.mpandroidchart
|
||||
implementation libs.jcip.annotations
|
||||
|
||||
// Test Dependencies
|
||||
androidTestImplementation libs.androidx.test.junit
|
||||
|
||||
@@ -1,6 +0,0 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<background android:drawable="@color/bg_app_icon_test"/>
|
||||
<foreground android:drawable="@drawable/ic_launcher_foreground_test"/>
|
||||
<monochrome android:drawable="@drawable/ic_launcher_foreground_monochrome"/>
|
||||
</adaptive-icon>
|
||||
@@ -1,6 +0,0 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<background android:drawable="@color/bg_app_icon_debug"/>
|
||||
<foreground android:drawable="@drawable/ic_launcher_foreground_debug"/>
|
||||
<monochrome android:drawable="@drawable/ic_launcher_foreground_monochrome"/>
|
||||
</adaptive-icon>
|
||||
@@ -1 +0,0 @@
|
||||
CoMaps - Camina, pedala o condueix privadament
|
||||
@@ -1,10 +1,8 @@
|
||||
• Karten-Daten vom 6. September
|
||||
• Zeitstrafen für Radrouting
|
||||
• Farbige POI-Beschriftungen in Autonavigation
|
||||
• POI-Suche nach Filialnamen
|
||||
• Abspannportale, Sicherheitskabinen & Büros hinzugefügt
|
||||
• Aktualisierte Symbole für Türme, Nachtclubs, Apotheken und Fahnenmasten
|
||||
• Lesezeichen-Farbe in GPX-Exporten
|
||||
• Farbfüllung von Fußgängerbereiche auf Plätzen
|
||||
• Android Auto: Anzeige Ausfahrtsnummern in Kreisverkehren
|
||||
Weitere Änderungen in Codeberg-Versionshinweisen!
|
||||
• OpenStreetMap-Daten vom 22. August
|
||||
• Neue Geschwindigkeitsanzeige & Details aufgezeichneter Strecken
|
||||
• Besserer dunkler Modus, neue farbige Labels
|
||||
• Anzeige wann Orte & Öffnungszeiten überprüft wurden
|
||||
• Routenplanung berücksichtigt Stoppschilder, Ampeln & bedingte Einschränkungen.
|
||||
• GPS-Peilung wird statt Kompass bevorzugt & höhere GPS-Frequenz.
|
||||
• Adressen & Notizen im OSM-Editor unterstützt.
|
||||
• Mehr Verbesserungen an UI-Elementen & Kartenstil, alle Details in den Codeberg-Versionshinweisen!
|
||||
|
||||
@@ -1,10 +1,9 @@
|
||||
• OpenStreetMap data as of September 6
|
||||
• Turn penalties for bicycle routing
|
||||
• Colored POI labels for car navigation map style
|
||||
• Search POIs by branch name
|
||||
• Added power portals, security booths and offices
|
||||
• Update icons for towers, nightclubs, chemists, flagpoles
|
||||
• Save bookmark color to GPX exports
|
||||
• Color fill pedestrian parts of squares
|
||||
• Android Auto: display roundabout exit numbers
|
||||
• OpenStreetMap data as of August 22
|
||||
• New current speed indicator, display track info
|
||||
• Improved dark map style, added coloured labels
|
||||
• Display when places & opening hours were last checked
|
||||
• Routing now considers turns, stop signs, lights & conditional restrictions
|
||||
• Prefer GPS bearing over compass and increase location poll rate
|
||||
• Enable adding standalone addresses & notes in the editor
|
||||
• Various UI element & map style improvements
|
||||
Check our Codeberg release notes for more changes!
|
||||
|
||||
@@ -1,10 +1,9 @@
|
||||
• Datos a 6 de septiembre
|
||||
• Penalizaciones de giros en rutas de bici
|
||||
• Etiquetas de puntos de interés en color en navegación
|
||||
• Buscar por nombre de sucursal
|
||||
• Añadir portales de energía, cabinas de seguridad y oficinas
|
||||
• Nuevos iconos: torres, discotecas, parafarmacias y mástiles
|
||||
• Guardar color en exportaciones GPX
|
||||
• Colorear áreas peatonales de plazas
|
||||
• Android Auto: mostrar números de salida de rotondas
|
||||
Más detalles en Codeberg
|
||||
• Datos de OSM a 22-08-2025
|
||||
• Nuevo indicador de velocidad e información de pista
|
||||
• Modo oscuro mejorado y nombres de POI coloreados
|
||||
• Indicador de última revisión de lugares y horarios de apertura
|
||||
• Rutas mejoradas teniendo en cuenta giros, señales de STOP, semáforos y restricciones
|
||||
• Mayor precisión para determinar tu localización y sentido
|
||||
• Añade direcciones y notas con el editor
|
||||
• Otras mejoras en elementos de la interfaz y estilo del mapa
|
||||
Entra en nuestro Codeberg para más cambios!
|
||||
|
||||
@@ -1 +1 @@
|
||||
Navegación sencilla - Descubre más en tu camino - Creado por la comunidad
|
||||
Navegación de mapa fácil - Descubre más en tu camino - Creado por la comunidad
|
||||
|
||||
@@ -1,34 +1,32 @@
|
||||
Yhteisön johtama vapaa ja avoimeen lähdekoodiin perustuva karttasovellus, jonka karttadata perustuu OpenStreetMap:n avoimeen dataan. Sovelluksessa painottuu vahva sitoutuminen läpinäkyvyyteen, yksityisyyteen ja voittoa tavoittelemattomaan toimintaan. CoMaps on haarautunut Organic Maps:sta, joka taas omalta osaltaan on haarautunut Maps.ME:stä.
|
||||
Yhteisövetoinen, ilmainen ja avoimeen lähdekoodiin perustuva karttasovellus, jonka pohjalla käytetään OpenStreetMapin avointa karttadataa. Sovelluksen kehityksessä on sitouduttu läpinäkyvyyteen, yksityisyyteen ja voittoa tavoittelemattomuuteen. CoMapsin projekti on haarautunut Organic Mapsista, joka taas on haarautunut aiemmin Maps.ME:stä
|
||||
|
||||
Lue tarkemmin projektin syistä ja sen suunnasta osoitteesta <b><i>codeberg.org/comaps</i></b>.
|
||||
Liity yhteisöön ja auta kehittämään parasta karttasovellusta
|
||||
• Käytä sovellusta ja levitä siitä sanaa
|
||||
• Anna palautetta ja raportoi ongelmista
|
||||
• Päivitä karttadataa sovelluksessa tai OpenStreetMap:n verkkosivuilla
|
||||
Lue lisää projektin tavotteista ja suunnasta osoitteesta <b><i>codeberg.org/comaps</i></b>.
|
||||
Liity yhteisöön ja auta kehittämään paras saatavilla oleva karttasovellus
|
||||
• Käytä sovellusta ja kerro siitä myös muille
|
||||
• Anna palautetta ja raportoi ongelmia
|
||||
• Päivitä karttoja, joko sovelluksessa tai OpenStreetMapin verkkosivuilla
|
||||
|
||||
‣ <b>Offline-painotteinen</b>: Suunnittele ja navigoi matkasi ilman verkkoyhteyttä. Etsi reittipisteitä retkilläsi. Kaikki sovelluksen toiminnot on suunniteltu käytettäväksi ilman verkkoyhteyttä.
|
||||
‣ <b>Kunnioittaa yksityisyyttä</b>: Sovellus on suunniteltu yksityisyyttä silmälläpitäen. Sovellu ei tunnista ihmisä, seuraa toimintaasi, eikä kerää henkilökohtaisia tietojasi. Mainosvapaa.
|
||||
‣ <b>Yksinkertainen ja viimeistelty</b>: Olennaiset ominaisuudet, joita on helppo käyttää.
|
||||
‣ <b>Säästää akkua ja tilaa</b>: Ei kuluta akkua, kuten toiset karttasovellukset. Kompaktit kartat säästävät tilaa puhelimessasi.
|
||||
‣ <b>Ilmainen ja yhteisön rakentama</b>: Ihmiset, kuten sinä ovat auttaneet sovelluksen kehityksessä lisäämällä paikkoja OpenStreetMap:iin, testaamalla sovellusta ja antamalla palautetta. Voit auttaa myös kehittämällä sovellusta ja lahjoittamalla sovelluskehitykseen.
|
||||
‣ <b>Avoin ja läpinäkyvä päätöksenteko ja rahoitus. Voittoa tavoittelematon ja täysin avoimeen lähdekoodiin perustuva.</b>
|
||||
‣ <b>Offline-painotteinen</b>: Suunnittele ja navigoi ulkomailla ilman mobiiliverkkoja. Kaikki sovelluksen toiminnot on suunniteltu käytettäväksi ilman verkkoyhteyttä.
|
||||
‣ <b>Kunnioittaa yksityisyyttä</b>: Sovellus on suunniteltu yksilön yksityisyys silmälläpitäen. Sovellus ei tunnista tai kerää tietoja sinusta. Mainosvapaa.
|
||||
‣ <b>Yksinkertainen ja viimeistelty</b>: Olennaiset ominaisuudet, joita on helppo käyttää.
|
||||
‣ <b>Säästä akkua ja tallennustilaa</b>: Ei kuluta akkua, kuten muut navigointisovellukset. Kompaktit kartat säästävät arvokasta tallennustilaa puhelimessasi.
|
||||
‣ <b>Ilmainen ja yhteisön luoma</b>: Vapaaehtoiset, kuten sinä olette auttaneet sovelluksen kehityksessä lisäämällä paikkoja OpenStreetMap:iin, testaamalla sovellusta ja antamalla palautetta. Voit myös auttaa kehittämällä ominaisuuksia ja lahjoittamalla sovelluskehitykseen
|
||||
‣ <b>Avoin ja läpinäkyvä päätöksenteko sekä rahoitus. Voittoa tavoittelematon ja täysin avoimeen lähdekoodiin perustuva.</b>
|
||||
|
||||
<b>Tärkeimmät ominaisuudet</b>:
|
||||
<ul>
|
||||
<li>Ladattavat yksityiskohtaiset kartat paikoista, joita ei löydy edes Google Maps:sta</li>
|
||||
<li>Ulkoilutila, josta löytyy korostettuna reitit, leirintäpaikat, vesipisteet, huiput ja korkeuserot yms.</li>
|
||||
<li>Kävely- ja pyörätiet</li>
|
||||
<li>Kiinnostavat paikat, kuten ravintolat, huoltoasemat, hotellit, kaupat, nähtävyydet ja monta muuta</li>
|
||||
<li>Etsi nimellä, osoitteella tai kiinnostavan paikan kategorialla</li>
|
||||
<li>Navigointi ääni-ilmoituksilla kävellessä, pyöräillessä tai ajaessa</li>
|
||||
<li>Tallenna suosikkipaikkasi yhdellä napautuksella</li>
|
||||
<li>Offline Wikipedia-artikkelit</li>
|
||||
<li>Maanalaisen liikenteen tasot ja ohjeet</li>
|
||||
<li>Reittien tallennus</li>
|
||||
<li>Tuo ja vie kirjanmerkkejä ja reittejä KML-, KMZ- ja GPX-formaateissa</li>
|
||||
<li>Tumma tila iltaa ja yötä varten</li>
|
||||
<li>Paranna karttadataa kaikille sisäänrakennetulla editorilla</li>
|
||||
</ul>
|
||||
• Ladattavat yksityiskohtaiset kartat paikoista, joita ei löydy edes Google Maps:sta
|
||||
• Ulkoilutila, josta löytyy korostettuna reitit, leirintäpaikat, vesipisteet, huiput ja korkeuserot yms.
|
||||
• Kävely- ja pyörätiet
|
||||
• Kiinnostavat paikat, kuten ravintolat, huoltoasemat, hotellit, kaupat, nähtävyydet ja monta muuta
|
||||
• Etsi nimellä, osoitteella tai kiinnostavan paikan kategorialla
|
||||
• Navigointi ääni-ilmoituksilla kävellessä, pyöräillessä tai ajaessa
|
||||
• Tallenna suosikkipaikkasi yhdellä napautuksella
|
||||
• Offline Wikipedia-artikkelit
|
||||
• Maanalaisen liikenteen tasot ja ohjeet
|
||||
• Reittien tallennus
|
||||
• Tuo ja vie kirjanmerkkejä ja reittejä KML-, KMZ- ja GPX-formaateissa
|
||||
• Tumma tila iltaa ja yötä varten
|
||||
• Paranna karttadataa kaikille sisäänrakennetulla editorilla
|
||||
|
||||
<b>Vapaus on täällä</b>
|
||||
Löydä matkasi, navigoi maailmassa yksityisyyden ja yhteisön tukemana!
|
||||
Löydä matkasi ja navigoi maailmalla yksityisyyden ja yhteisön tukemana!
|
||||
|
||||
@@ -1 +1 @@
|
||||
CoMaps - Navigoi yksityisesti ilman verkkoyhteyttä
|
||||
CoMaps - Navigoi ilman verkkoyhteyttä yksityisesti
|
||||
|
||||
@@ -1,9 +1,9 @@
|
||||
• Données OSM du 06 septembre
|
||||
• Pénalités dans les calculs d'itinéraires vélos
|
||||
• Ajout de labels colorés en mode navigation
|
||||
• Support du tag branch dans la recherche
|
||||
• Ajout des portiques électriques, postes de sécurité
|
||||
• Mise à jour des icônes de tours, boîtes de nuits, chimiste et mat
|
||||
• Enregistrement de la couleur des signets dans les exports GPX
|
||||
• Android Auto: Affichage du numéro de sortie des ronds-points
|
||||
• Données OSM du 22 août
|
||||
• Nouvel indicateur de vitesse et détails des pistes
|
||||
• Amélioration du style sombre, ajout de labels colorées
|
||||
• Affichage de la date de dernière vérification d'un lieu
|
||||
• Support dans le routage des virages, signalisations et restrictions
|
||||
• Amélioration de la boussole et de la précision GPS
|
||||
• Support des adresses et des notes dans l'éditeur
|
||||
• Diverses améliorations d'UI et du style de la carte
|
||||
Plus d'informations sur notre Codeberg
|
||||
|
||||
@@ -1 +1 @@
|
||||
Navigation facile - Vivez de grands voyages - Propulsé par la communauté
|
||||
Navigation de cartes facile - Découvrez le monde - Propulsé par la communauté
|
||||
|
||||
@@ -1,32 +1,32 @@
|
||||
Egy közösség által vezetett, ingyenes és nyílt forráskódú térképalkalmazás, amely az OpenStreetMap adatain alapul, és amelynek alapelvei a átláthatóság, az adatvédelem és a nonprofit működés. A CoMaps az Organic Maps alkalmazás egyik változata, amely viszont a Maps.ME alkalmazás egyik változata.
|
||||
A CoMaps egy közösség által létrehozott, ingyenes és nyílt forráskódú térképalkalmazás, amely az OpenStreetMap térképadatain alapul, és amelyet az átláthatóság, a magánélet védelme és a nonprofit jelleg iránti elkötelezettség erősít. A CoMaps az Organic Maps villája, amely viszont a Maps.ME villája.
|
||||
|
||||
A projekt előzményeiről és fejlesztési irányáról bővebben a <b><i>codeberg.org/comaps</i></b> oldalon olvashat.
|
||||
Csatlakozzon a közösséghez, és segítsen a legjobb térképalkalmazás létrehozásában
|
||||
• Használja az alkalmazást, és terjessze a hírt róla
|
||||
• Adjon visszajelzést, és jelentsen problémákat
|
||||
• Frissítse a térképadatokat az alkalmazásban vagy az OpenStreetMap weboldalon
|
||||
A projekt előzményeiről és az irányáról a <b><i>codeberg.org/comaps</i></b> oldalon olvashatsz.
|
||||
Csatlakozz ott a közösséghez, és segíts a legjobb térképalkalmazás elkészítésében.
|
||||
• Használd az alkalmazást és terjeszd a hírét
|
||||
• Adj visszajelzést és jelentsd a problémákat
|
||||
• Frissítsd és javítsd a térképadatokat az alkalmazásban vagy az OpenStreetMap weboldalán.
|
||||
|
||||
‣ <b>Offline</b>: Tervezze meg és navigálja külföldi utazását mobilszolgáltatás nélkül, keressen útpontokat távoli túrákon stb. Az alkalmazás összes funkciója úgy van kialakítva, hogy offline is működjön.
|
||||
‣ <b>A magánélet tiszteletben tartása</b>: Az alkalmazás a magánélet tiszteletben tartásával lett kialakítva – nem azonosítja az embereket, nem követi nyomon őket és nem gyűjt személyes adatokat. Reklámmentes.
|
||||
‣ <b>Egyszerű és kifinomult</b>: alapvető, könnyen használható funkciók, amelyek egyszerűen működnek.
|
||||
‣ <b>Takarékos az akkumulátorral és a tárhellyel</b>: Nem meríti le az akkumulátort, mint más navigációs alkalmazások. A kompakt térképek értékes helyet takarítanak meg a telefonon.
|
||||
‣ <b>Ingyenes és a közösség által fejlesztett</b>: Az Önhöz hasonló emberek segítettek az alkalmazás fejlesztésében azzal, hogy helyeket adtak hozzá az OpenStreetMaphez, tesztelték és visszajelzéseket adtak a funkciókról, valamint fejlesztői ismereteikkel és pénzzel is hozzájárultak a fejlesztéshez.
|
||||
‣ <b>Nyílt, átlátható döntéshozatal és pénzügyek, nonprofit és teljesen nyílt forráskódú.
|
||||
‣ <b>Offline-fókuszú:</b> Tervezd meg és navigáld külföldi útad mobilszolgáltatás nélkül, keress útpontokat egy távoli túra során stb. Az alkalmazás minden funkcióját úgy terveztük, hogy internetkapcsolat nélkül is működjön.
|
||||
‣ <b>A magánélet tiszteletben tartása:</b> Az alkalmazás az adatvédelem szem előtt tartásával készült, nem azonosítja az embereket, nem követi nyomon és nem gyűjt személyes adatokat, és reklámmentes.
|
||||
‣ <b>Takarékosdik az akkumulátorral és a tárhellyel:</b> Nem meríti le az akkumulátort, mint más navigációs alkalmazások. A jól összeállítot kis méretű térképek értékes helyet takarítanak meg a telefonon.
|
||||
‣ <b>Egyszerű és szép grafikus felület,</b> nagyszerű és könnyen használható funkciók, amelyek egyszerűen működnek.
|
||||
‣ <b>Ingyenes és a közösség által készített:</b> A hozzád hasonló emberek segítettek az alkalmazás létrehozásában azáltal, hogy hozzáadtak helyeket az OpenStreetMap térképhez, tesztelték és visszajelzést adtak a funkciókról, valamint hozzájárultak a fejlesztői képességeikkel és a pénzükkel.
|
||||
‣ <b>Nyílt és átlátható döntéshozatal és pénzügyek, nonprofit és teljesen nyílt forráskódú.</b>
|
||||
|
||||
<b>Főbb jellemzők</b>:
|
||||
• Letölthető részletes térképek olyan helyekkel, amelyek nem érhetők el a Google Maps-en
|
||||
• Kültéri mód kiemelt túraútvonalakkal, kempingekkel, vízforrásokkal, csúcsokkal, szintvonalakkal stb.
|
||||
• Gyalogos és kerékpáros útvonalak
|
||||
• Érdekes helyek, például éttermek, benzinkutak, szállodák, üzletek, látnivalók és még sok más
|
||||
• Keresés név, cím vagy érdekes hely kategória alapján
|
||||
• Hangos navigáció gyalogos, kerékpáros vagy autós utazáshoz
|
||||
• Kedvenc helyek könyvjelzővel egyetlen érintéssel
|
||||
• Offline Wikipedia cikkek
|
||||
• Metróhálózat és útvonaltervezés
|
||||
• Útvonalrögzítés
|
||||
• Könyvjelzők, útvonalak exportálása és importálása KML, KMZ, GPX formátumokban
|
||||
• Sötét mód az éjszakai használathoz
|
||||
• A beépített alapszerkesztővel mindenki javíthatja a térképadatokat
|
||||
<b>Főbb jellemzők:</b>
|
||||
• Letölthető részletes térképek olyan helyekkel, amelyek sok kereskedelmi térképen nem állnak rendelkezésre.
|
||||
• Szabadtéri üzemmód kiemelt túraútvonalakkal, táborhelyekkel, vízforrásokkal, csúcsokkal, szintvonalakkal stb.
|
||||
• Sétaútvonalak és kerékpárutak
|
||||
• Érdekes pontok, mint például éttermek, benzinkutak, szállodák, üzletek, látnivalók és még sok minden más
|
||||
• Keresés név, cím vagy az érdekes pontok kategóriája alapján
|
||||
• Navigáció hangutasításokkal gyalogláshoz, kerékpározáshoz vagy vezetéshez
|
||||
• Kedvenc helyeid könyvjelzővel láthatod el egyetlen érintéssel
|
||||
• Wikipedia szócikkek internetkapcsolat nélkül
|
||||
• Metró tranzit réteg és irányok
|
||||
• Útvonal mentése
|
||||
• Könyvjelzők és nyomvonalak exportálása és importálása KML, KMZ, GPX formátumokban
|
||||
• Sötét üzemmód az éjszakai használathoz
|
||||
• Térképadatok javítása mindenki számára egy alapvető beépített szerkesztő segítségével
|
||||
|
||||
<b>A szabadság itt van</b>
|
||||
Fedezze fel utazását, navigáljon a világban, ahol az adatvédelem és a közösség az első!
|
||||
<b>Itt van a szabadság</b>
|
||||
Fedezd fel az utadat, navigálj a világban úgy, hogy a magánélet és a közösség kerüljön előtérbe!
|
||||
|
||||
@@ -1 +1 @@
|
||||
Egyszerű térképnavigáció – Fedezze fel utazását – A közösség támogatásával
|
||||
Könnyű térképes navigáció - Fedezz fel többet az útjaidról - A közösség erejével
|
||||
|
||||
@@ -1 +1 @@
|
||||
CoMaps – túrázás, kerékpározás, autózás offline
|
||||
CoMaps - Túra, Bicikli, Vezetés offline diszkréten
|
||||
|
||||
@@ -1,10 +0,0 @@
|
||||
• OpenStreetMap aggiornato al 6 Settembre
|
||||
• Bici: miglior stima del tempo di percorrenza
|
||||
• Auto: punti d'interesse colorati
|
||||
• Cerca i punti d'interesse tramite filiale
|
||||
• Aggiunte strutture alta tensione, cabine di sicurezza e uffici
|
||||
• Aggiornate le icone per torri, discoteche, farmacie e aste per bandiere
|
||||
• Salva il colore dei Preferiti nel GPX
|
||||
• Evidenziate le aree pedonali nelle piazze
|
||||
• AndroidAuto: aggiunto il numero dell'uscita nelle rotonde
|
||||
Visita Codeberg per ulteriori dettagli
|
||||
@@ -1 +0,0 @@
|
||||
Vienkārša kartes navigācija - Atklāj vairāk par savu ceļojumu - Darbina kopiena
|
||||
@@ -1 +0,0 @@
|
||||
CoMaps - dodies ceļā bezsaistē ar privātumu
|
||||
@@ -1,32 +0,0 @@
|
||||
App għall-mapep b'xejn u b'sors miftuħ (open source) immexxi mill-komunità bbażata fuq dejta minn OpenStreetMap, b'impenn għal trasparenza, privatezza u mhux għal-profitt. CoMaps hija fork ta' Organic Maps, li min-naħa tagħha hija fork ta' Maps.ME.
|
||||
|
||||
Kompli aqra dwar ir-raġunijiet għall-proġett u d-direzzjoni tiegħu hawn <b><i>codeberg.org/comaps</i></b>.
|
||||
Ingħaqad mal-komunità u għin biex toħloq l-aqwa app tal-mapep
|
||||
• Uża l-app u semmiha ma' min taf
|
||||
• Agħti feedback u rrapporta problemi
|
||||
• Aġġorna d-dejta tal-mapep fl-app jew fuq il-websajt OpenStreetMap
|
||||
|
||||
‣ <b>Iffokata fuq offlajn</b>: Ippjana u innaviga l-vjaġġ tiegħek barra minn pajjiżek mingħajr ħtieġa ta' servizz ċellulari, fittex waypoints waqt ħajk, eċċ. Il-funzjonijiet kollha tal-app huma ddisinjati biex jaħdmu offlajn.
|
||||
‣ <b>Tirrispetta l-Privatezza</b>: L-app hija ddisinjata bil-privatezza f'moħħha - ma tidentifikax nies, ma ssegwikx, u ma tiġborx informazzjoni personali. Bla reklami.
|
||||
‣ <b>Sempliċi u Rfinuta</b>: karatteristiċi essenzjali, faċli biex jintużaw u li sempliċement jaħdmu.
|
||||
‣ <b>Tiffrankalek Batterija u Spazju</b>: Ma taħlix il-batterija bħal apps oħra tal-mapep. Mapep kompatti li jiffrankawlek spazju prezzjuż fuq il-mowbajl.
|
||||
‣ <b>B'xejn u Mibnija mill-Komunità</b>: Nies bħalek għenu fl-iżvilupp tal-app billi żiedu postijiet f'OpenStreetMap, ittestjaw u taw feedback dwar il-karatteristiċi u kkontribwew il-ħiliet u l-flus tagħhom.
|
||||
‣ <b>Trasparenza fil-finanzi u fit-teħid ta' deċiżjonijiet, Mhux għall-profitt u sors kompletament miftuħ.</b>
|
||||
|
||||
<b>Karatteristiċi Prinċipali</b>:
|
||||
• Mapep dettaljati li jistgħu jitniżżlu b'postijiet li mhumiex disponibbli fuq Google Maps
|
||||
• Modalità ta' barra b'mogħdijiet tal-mixi, postijiet għal-ikkampjar, sorsi tal-ilma, quċċati, linji tal-kontorn, eċċ.
|
||||
• Mogħdijiet għall-mixi u rotti għar-roti
|
||||
• Postijiet ta' interess bħal ristoranti, stazzjonijiet tal-petrol, lukandi, ħwienet, postijiet turistiċi u ħafna aktar
|
||||
• Fittex bl-isem jew bl-indirizz jew bil-kategorija interess
|
||||
• Navigazzjoni b'avviżi bil-vuċi għall-mixi, ċikliżmu, u sewqan
|
||||
• Immarka l-postijiet favoriti tiegħek b'tapp waħda
|
||||
• Artikli offlajn ta' Wikipedia
|
||||
• Direzzjonijiet tas-subways
|
||||
• Reġistrazzjoni ta' trekks
|
||||
• Esportazzjoni u importazzjoni ta' bookmarks u trekks f'formati KML, KMZ, GPX
|
||||
• Modalità mudlama biex tintuża bil-lejl
|
||||
• Ittejjeb id-dejta tal-mapep għal kulħadd b'użu ta' editur bażiku u integrat
|
||||
|
||||
<b>Il-Libertà Waslet</b>
|
||||
Skopri l-vjaġġ tiegħek, innaviga d-dinja bil-privatezza u bil-komunità fuq quddiem nett!
|
||||
@@ -1 +0,0 @@
|
||||
Navigazzjoni ta' mapep faċli - Skopri iktar mill-vjaġġ - Imsaħħaħ mill-komunita`
|
||||
@@ -1 +0,0 @@
|
||||
CoMaps - Imxi, Suq Rota u Karozza bil-Privatezza
|
||||
@@ -1,32 +0,0 @@
|
||||
Prowadzona przez społeczność, darmowa i otwartoźródłowa aplikacja mapowa oparta na danych OpenStreetMap, wzmacniana zobowiązaniem do transparentności, prywatności i działalnością non-profit. CoMaps jest forkiem/spin-off'em Organic Maps, który z kolei jest forkiem Maps.ME.
|
||||
|
||||
Przeczytaj o powodach powstania projektu i jego kierunku na stronie <b><i>codeberg.org/comaps</i></b>.
|
||||
Dołącz do społeczności i pomóż stworzyć najlepszą aplikację mapową
|
||||
• Używaj aplikacji i rozpowszechnia o niej informacje,
|
||||
• Przekazuj opinie i zgłaszaj problemy,
|
||||
• Aktualizuj dane w aplikacji lub na stronie OpenStreetMap.
|
||||
|
||||
‣ <b>Skoncentrowana na pracy w trybie offline</b>: Zaplanuj trasę i nawiguj podczas swojej podróży za granicą bez potrzeby korzystania z sieci komórkowej, wyszukuj punkty nawigacyjne podczas dalekich wędrówek itp. Wszystkie funkcje aplikacji zostały zaprojektowane do pracy w trybie offline.
|
||||
‣ <b>Poszanowanie prywatności</b>: Aplikacja została zaprojektowana z myślą o prywatności – nie identyfikuje osób, nie śledzi ich i nie gromadzi danych osobowych. Bez reklam.
|
||||
‣ <b>Prosta i dopracowana</b>: niezbędne, łatwe w użyciu funkcje, które po prostu działają.
|
||||
‣ <b>Oszczędza baterię i miejsce</b>: Nie wyczerpuje baterii jak inne aplikacje nawigacyjne. Kompaktowe mapy oszczędzają cenne miejsce w telefonie.
|
||||
‣ <b>Darmowa i stworzona przez społeczność</b>: Osoby takie jak Ty pomogły w tworzeniu aplikacji, dodając miejsca do OpenStreetMap, testując i przekazując opinie na temat funkcji oraz wnosząc swoje umiejętności programistyczne i pieniądze.
|
||||
‣ <b>Otwarte i transparentne podejmowanie decyzji i zarządzanie finansami, nie dla zysku i w pełni otwartoźródłowe.</b>
|
||||
|
||||
<b>Główne funkcje</b>:
|
||||
• Szczegółowe mapy do pobrania z miejscami niedostępnymi na wielu mapach komercyjnych,
|
||||
• Tryb outdoorowy z wyróżnionymi szlakami turystycznymi, kempingami, źródłami wody, szczytami, poziomicami itp.,
|
||||
• Ścieżki spacerowe i rowerowe,
|
||||
• Punkty zainteresowania, takie jak restauracje, stacje benzynowe, hotele, sklepy, atrakcje turystyczne i wiele innych,
|
||||
• Wyszukiwanie według nazwy, adresu lub kategorii punktu zainteresowania,
|
||||
• Nawigacja z komunikatami głosowymi dla pieszych, rowerzystów i kierowców,
|
||||
• Dodawanie zakładek do ulubionych miejsc jednym dotknięciem,
|
||||
• Artykuły z Wikipedii offline,
|
||||
• Warstwa z liniami metra oraz nawigacja z użyciem metra,
|
||||
• Nagrywanie tras,
|
||||
• Eksport i import zakładek i tras w formatach KML, KMZ i GPX,
|
||||
• Ciemny tryb do użytku w nocy,
|
||||
• Ulepszanie danych mapowych dzięki wbudowanemu edytorowi.
|
||||
|
||||
<b>Wolność jest tutaj</b>
|
||||
Odkrywaj swoją podróż, nawiguj po świecie z prywatnością i społecznością na pierwszym planie!
|
||||
@@ -1 +0,0 @@
|
||||
Łatwa nawigacja – Odkryj więcej ze swojej podróży – Wspierane przez społeczność
|
||||
@@ -1 +0,0 @@
|
||||
CoMaps - Nawiguj offline z zachowaniem prywatności
|
||||
@@ -1,10 +1,8 @@
|
||||
• Dados OSM de 6/09
|
||||
• Penalidades de conversão para bicicleta
|
||||
• Etiquetas de POI coloridas para o estilo do mapa de navegação de carros
|
||||
• Busca de POIs por nome de filial
|
||||
• Adição de portais de energia, guaritas e escritórios
|
||||
• Atualização de ícones para torres, discotecas, farmácias e mastros
|
||||
• Salva a cor dos favoritos nas exportações GPX
|
||||
• Preenchimento de praças pavimentadas
|
||||
• Android Auto: exibe números de saída de rotatória
|
||||
Confira nossas notas de lançamento do Codeberg para mais mudanças
|
||||
• Dados OSM de 22/08
|
||||
• Novo indicador de velocidade e tela de informações de trilha
|
||||
• Melhor estilo de mapa escuro, rótulos coloridos adicionados
|
||||
• Exibição da última atualização de locais e horários de funcionamento
|
||||
• O roteamento agora considera conversões, PARE, semáforos, e restrições condicionais
|
||||
• Preferência por orientação GPS em vez de bússola e aumento da frequência de localização
|
||||
• Editor: adição de endereços e notas independentes
|
||||
• Melhorias em elementos da interface e estilo de mapa
|
||||
|
||||
@@ -1,32 +0,0 @@
|
||||
O aplicație de hărți gratuită & open source, condusă de comunitate, bazată pe date OpenStreetMap și întărită prin angajament față de transparență, confidențialitate și statut non-profit. CoMaps este un fork/spin-off al Organic Maps, care la rândul său este un fork al Maps.ME.
|
||||
|
||||
Citește mai multe despre motivele proiectului și direcția sa pe <b><i>codeberg.org/comaps</i></b>.
|
||||
Alătură-te comunității de acolo și ajută la crearea celei mai bune aplicații de hărți:
|
||||
• Folosește aplicația și promovează-o
|
||||
• Oferă feedback și raportează probleme
|
||||
• Actualizează datele hărților în aplicație sau pe site-ul OpenStreetMap
|
||||
|
||||
‣ <b>Orientare offline</b>: Planifică-ți și navighează-ți călătoria în străinătate fără nevoia unui semnal cellular, caută puncte de reper în timpul unei drumeții îndepărtate etc. Toate funcțiile aplicației sunt concepute să funcționeze offline.
|
||||
‣ <b>Respectă confidențialitatea</b>: Aplicația este concepută cu confidențialitatea în minte - nu identifică persoanele, nu urmărește și nu colectează informații personale. Fără reclame.
|
||||
‣ <b>Simplă și rafinată</b>: caracteristici esențiale, ușor de utilizat, care funcționează fără probleme.
|
||||
‣ <b>Economisește bateria și spațiul</b>: Nu consumă bateria la fel de mult ca alte aplicații de navigație. Hărțile compacte economisesc spațiu prețios pe telefon.
|
||||
‣ <b>Gratuită și construită de comunitate</b>: Oameni ca tine au contribuit la construirea aplicației prin adăugarea de locații pe OpenStreetMap, testare și oferire de feedback pentru funcții, și prin contribuția cu abilități de dezvoltare și finanțare.
|
||||
‣ <b>Decizii și finanțare deschise și transparente, non-profit și cu sursă complet deschisă (open source)</b>.
|
||||
|
||||
<b>Caracteristici principale</b>:
|
||||
• Hărți detaliate, descărcabile, cu locații care nu sunt disponibile pe Google Maps
|
||||
• Mod pentru activități în aer liber cu trasee de drumeție marcate, locuri de campat, surse de apă, vârfuri, linii de contur etc.
|
||||
• Căi pietonale și piste de ciclism
|
||||
• Puncte de interes precum restaurante, benzinării, hoteluri, magazine, obiective turistice și multe altele
|
||||
• Căutare după nume, adresă sau categorie de punct de interes
|
||||
• Navigație cu anunțuri vocale pentru mers pe jos, cu bicicleta sau cu mașina
|
||||
• Marchează-ți locațiile preferate cu un singur clic
|
||||
• Articole Wikipedia offline
|
||||
• Strat pentru metrou și indicații de traseu
|
||||
• Înregistrare trasee
|
||||
• Exportă și importă marcaje și trasee în formatele KML, KMZ, GPX
|
||||
• Un mod întunecat pentru utilizare nocturnă
|
||||
• Îmbunătățește datele hărții pentru toți, folosind un editor de bază integrat
|
||||
|
||||
<b>Libertatea este aici</b>
|
||||
Descoperă-ți călătoria, navighează prin lume având în frunte confidențialitatea și comunitatea!
|
||||
@@ -1 +0,0 @@
|
||||
Navigare ușoară - Descoperă mai mult din călătoria ta - Susținut de comunitate
|
||||
@@ -1,10 +1,9 @@
|
||||
• Данные на 6 сентября
|
||||
• Предупреждения на веломаршруте
|
||||
• Цветные метки POI при автонавигации
|
||||
• Поиск POI по названию ветки
|
||||
• Добавлены высоковольтные опоры, помещения охраны и офисы
|
||||
• Обновлены значки башен,вышек,мачт,ночных клубов,аптек
|
||||
• Сохранение цвета закладок при экспорте в GPX (через OM)
|
||||
• Отображение цветом пешеходных зон
|
||||
• Android Auto: отображение номеров съездов на кольцевых развязках
|
||||
Посмотрите примечания к выпуску Codeberg, чтобы узнать о других изменениях!
|
||||
• Данные 22 августа
|
||||
• Новый спидометр,информация о маршруте
|
||||
• Улучшен тёмный стиль,цветные метки
|
||||
• Время последней проверки часов работы
|
||||
• Построении маршрута учитывает повороты, знак «Стоп»,светофоры и ограничения
|
||||
• Предпочтение отдается GPS-координатам,а не компасу,увеличена частота опроса местоположения
|
||||
• Можно добавлять отдельные адреса и заметки в редакторе
|
||||
• Улучшены различные элементы пользовательского интерфейса и стиль карты
|
||||
Ознакомьтесь с примечания к релизу про изменения!
|
||||
|
||||
@@ -1 +0,0 @@
|
||||
Jednoduchá navigácia - Objav viac zo svojej cesty - Funguje vďaka komunite
|
||||
@@ -1 +0,0 @@
|
||||
CoMaps - kráčaj, bicykluj a jazdi v súkromí
|
||||
@@ -1 +0,0 @@
|
||||
Enostavna navigacija – Odkrij več o svojem potovanju – Podprto v skupnosti
|
||||
@@ -1 +0,0 @@
|
||||
CoMaps–Hodi, kolesari, vozi brez povezave, zasebno
|
||||
@@ -1,4 +1,4 @@
|
||||
Бесплатна апликација отвореног кода коју одржава заједница и која се заснива на ОpenStreetMap подацима. Непрофитна, транспарентна и цени вашу приватност. CoMaps је настала од апликације Organic Maps, која је настала од апликације Maps.ME.
|
||||
Бесплатна апликација отвореног кода коју одржава заједница, која се заснива на ОpenStreetMap подацима. Непрофитна, транспарентна и цени вашу приватност. CoMaps је настала од апликације Organic Maps, које је настала од апликације Maps.ME.
|
||||
|
||||
Прочитајте о разлозима пројекта и његовог правца на <b><i>codeberg.org/comaps</i></b>
|
||||
Придружите се отвореној заједници и помозите да направимо најбољу апликацију за мапе
|
||||
@@ -10,7 +10,7 @@
|
||||
‣ <b>Поштовање приватности</b>: Апликација је осмишљена са приватношћу корисника на уму - не идентификује људе, не прати или прикупља личне податке. Нема реклама.
|
||||
‣ <b>Једноставно и елегантно</b>: Апликација је лака за употребу и једноставно функционише.
|
||||
‣ <b>Чува вашу батерију и простор</b>: Не троши батерију као остале апликације за навигацију. Компактне мапе чувају драгоцени простор на вашем телефону.
|
||||
‣ <b>Отворено и направљено од стране заједнице</b>: Људи попут вас су допринели развоју апликације додавањем локација на OpenStreetMap, тестирањем, давањем повратних информација о апликацији и помогли су својим програмерским вештинама и донацијама.
|
||||
‣ <b>Отворено и направљено од стране заједнице</b>: Људи попут вас су допринели развоју апликације додавањем локација на OpenStreetMap, тестирањем, давањем повратних информација о апликацији и помогли су својим програмерским вештинама и донацијама.
|
||||
‣ <b>Отворено и транспарентно доношење одлука и употреба донација, непрофитна и потпуно отвореног кода.</b>
|
||||
|
||||
<b> Главне карактеристике </b>:
|
||||
|
||||
@@ -1 +1 @@
|
||||
Једноставна навигација - Сазнајте више о свом путовању - Одржава заједница
|
||||
Једноставна навигација - Сазнајте више о свом путовању - Ради на бази заједнице
|
||||
|
||||
@@ -1 +1 @@
|
||||
CoMaps - пешачење, бицикл и вожња, са приватношћу
|
||||
CoMaps - пешачење, бицикл, вожња
|
||||
|
||||
|
Before Width: | Height: | Size: 777 KiB After Width: | Height: | Size: 961 KiB |
|
Before Width: | Height: | Size: 865 KiB After Width: | Height: | Size: 703 KiB |
|
Before Width: | Height: | Size: 1.4 MiB After Width: | Height: | Size: 1.5 MiB |
|
Before Width: | Height: | Size: 1.3 MiB After Width: | Height: | Size: 517 KiB |
|
Before Width: | Height: | Size: 1.0 MiB |
|
Before Width: | Height: | Size: 673 KiB |
@@ -1 +1 @@
|
||||
version: 2025.10.09-3-FDroid+25100903
|
||||
version: 2025.03.02-7-FDroid+25030207
|
||||
|
||||
@@ -0,0 +1 @@
|
||||
সহজ মানচিত্র নেভিগেশন - আপনার যাত্রা সম্পর্কে আরও জানুন - সম্প্রদায় কর্তৃক পরিচালিত
|
||||
1
android/app/src/google/play/listings/bn/title.txt
Normal file
@@ -0,0 +1 @@
|
||||
CoMaps - গোপনীয়তা সহ যাতায়াত
|
||||
@@ -1 +1 @@
|
||||
Navegación sencilla - Descubre más en tu camino - Creado por la comunidad
|
||||
Navegación de mapa fácil - Descubre más en tu camino - Creado por la comunidad
|
||||
|
||||
@@ -1 +1 @@
|
||||
Navigation facile - Vivez de grands voyages - Propulsé par la communauté
|
||||
Navigation cartographique facile - Vivez de grands voyages - Propulsé par la communauté
|
||||
|
||||
@@ -1 +1 @@
|
||||
CoMaps - Naviguez tranquille
|
||||
CoMaps - Naviguer sans suivi
|
||||
|
||||
@@ -1,36 +0,0 @@
|
||||
Egy közösség által létrehozott és működtetett, ingyenes és nyílt forráskódú térképalkalmazás, amely az OpenStreetMap adatain alapul, és amelynek alapelvei a átláthatóság, az adatvédelem és a nonprofit működés.
|
||||
|
||||
Csatlakozz a közösséghez, és segíts a legjobb térképalkalmazás létrehozásában!
|
||||
• Használd az alkalmazást, és terjesszd a hírt róla!
|
||||
• Adj visszajelzést, és jelentsd a problémákat!
|
||||
• Frissítsd a térképadatokat az alkalmazásban vagy az OpenStreetMap weboldalon!
|
||||
|
||||
<i>Visszajelzéseid és az 5 csillagos értékelésed a legjobb támogatás számunkra!</i>
|
||||
|
||||
‣ <b>Egyszerű és kifinomult</b>: alapvető, könnyen használható funkciók, amelyek egyszerűen működnek.
|
||||
‣ <b>Offline-központú</b>: Tervezd meg és navigálj a külföldi útjaidon mobilhálózat igénybevétele nélkül, keress útvonalpontokat távoli túrákon stb. Az alkalmazás összes funkciója úgy lett kialakítva, hogy internetkapcsolat nélkül is működjön.
|
||||
‣ <b>Tiszteletben tartja a magánéletet</b>: Az alkalmazás a magánélet tiszteletben tartásával lett kialakítva. Nem azonosítja az embereket, nem követi nyomon őket és nem gyűjt személyes adatokat. Reklámmentes.
|
||||
‣ <b>Kíméli az akkumulátort és helytakarékos</b>: Nem meríti le az akkumulátort, mint más navigációs alkalmazások. A kisméretű, jól összeállított térképek értékes helyet takarítanak meg a telefonon.
|
||||
‣ <b>Ingyenes és a közösség által fejlesztett</b>: A hozzád hasonló emberek segítettek az alkalmazás fejlesztésében azzal, hogy helyeket adtak hozzá az OpenStreetMaphez, tesztelték és visszajelzéseket adtak a funkciókról, valamint fejlesztői ismereteikkel és a pénzükkel is hozzájárultak a fejlesztéshez.
|
||||
‣ <b>Nyílt és átlátható döntéshozatal és pénzügyek, nonprofit és teljesen nyílt forráskódú.
|
||||
|
||||
<<b>Főbb jellemzők</b>:
|
||||
• Letölthető részletes térképek olyan helyekkel, amelyek nem érhetők el a Google Maps-en
|
||||
• Kültéri mód kiemelt túraútvonalakkal, kempingekkel, vízforrásokkal, csúcsokkal, kontúrvonalakkal, stb.
|
||||
• Túraútvonalak és kerékpárutak
|
||||
• Érdekes helyek, például éttermek, benzinkutak, szállodák, üzletek, látnivalók és még sok más
|
||||
• Keresés név, cím vagy érdekes hely kategória szerint
|
||||
• Hangos navigáció gyalogos, kerékpáros vagy autós utazáshoz
|
||||
• Kedvenc helyeid könyvjelzővel láthatod el egyetlen érintéssel
|
||||
• Offline Wikipedia cikkek
|
||||
• Metró közlekedési réteg és útvonalak
|
||||
• Útvonalrögzítés
|
||||
• Könyvjelzők és útvonalak exportálása és importálása KML, KMZ, GPX formátumokban
|
||||
• Sötét mód éjszakai használatra
|
||||
• A beépített alapszerkesztővel mindenki javíthatja a térképadatokat
|
||||
• Android Auto támogatás
|
||||
|
||||
Kérjük, jelentsd az alkalmazással kapcsolatos problémákat, javasolj ötleteket, és csatlakozz közösségünkhöz a <b><i>comaps.app</i></b> weboldalon.
|
||||
|
||||
<b>Itt van a szabadság</b>
|
||||
Fedezd fel utadat, navigálj a világban úgy, hogy az adatvédelem és a közösség kerüljön előtérbe!
|
||||
@@ -1 +1 @@
|
||||
Egyszerű térképnavigáció – Fedezze fel utazását – A közösség támogatásával
|
||||
Könnyű térképes navigáció - Fedezz fel többet az útjaidról - A közösség erejével
|
||||
|
||||
@@ -0,0 +1 @@
|
||||
Navigation facile del mappa – Discoperi tu viage – Alimentate per le communitate
|
||||
1
android/app/src/google/play/listings/ia/title.txt
Normal file
@@ -0,0 +1 @@
|
||||
CoMaps – Naviga private
|
||||
@@ -1 +0,0 @@
|
||||
Vienkārša kartes navigācija - Atklāj vairāk par savu ceļojumu - Darbina kopiena
|
||||
@@ -1 +0,0 @@
|
||||
CoMaps - kartes ar privātumu
|
||||
@@ -1 +1 @@
|
||||
CoMaps - ഓഫ്ലൈൻ നാവിഗേഷൻ
|
||||
കോമാപ്പ്സ് - സ്വകാര്യതയോടെ സഞ്ചരിക്കൂ
|
||||
|
||||
@@ -1 +1 @@
|
||||
CoMaps – Nawigacja offline
|
||||
CoMaps - Nawigacja szanująca prywatność
|
||||
|
||||
@@ -1,36 +0,0 @@
|
||||
O aplicație de hărți gratuită & open source, condusă de comunitate, bazată pe date OpenStreetMap și susținută de angajamentul față de transparență, confidențialitate și statutul non-profit.
|
||||
|
||||
Alătură-te comunității și ajută la crearea celei mai bune aplicații de hărți
|
||||
• Folosește aplicația și promovează-o
|
||||
• Oferă feedback și raportează probleme
|
||||
• Actualizează datele hărții în aplicație sau pe site-ul OpenStreetMap
|
||||
|
||||
<i>Feedback-ul și recenziile tale cu 5 stele sunt cel mai bun sprijin pentru noi!</i>
|
||||
|
||||
‣ <b>Simplă și Rafinată</b>: funcții esențiale, ușor de utilizat, care pur și simplu funcționează.
|
||||
‣ <b>Focusată pe Modul Offline</b>: Planifică-ți și navighează-ți călătoria în străinătate fără nevoia unui serviciu cellular, caută waypoint-uri în timpul unei drumeții îndepărtate etc. Toate funcțiile aplicației sunt concepute să funcționeze offline.
|
||||
‣ <b>Respectă Confidențialitatea</b>: Aplicația este concepută cu confidențialitatea în minte - nu identifică oamenii, nu urmărește și nu colectează informații personale. Fără reclame.
|
||||
‣ <b>Îți Economisește Bateria și Spațiul</b>: Nu-ți golește bateria ca alte aplicații de navigație. Hărțile compacte economisesc spațiu prețios pe telefon.
|
||||
‣ <b>Gratuită și Construită de Comunitate</b>: Oameni ca tine au contribuit la construirea aplicației prin adăugarea de locuri pe OpenStreetMap, testare și oferire de feedback privind funcțiile și contribuind cu abilități de dezvoltare și bani.
|
||||
‣ <b>Decizii și Finanțe Deschise și Transparente, Non-profit și Complet Open Source.</b>
|
||||
|
||||
<b>Funcționalități principale</b>:
|
||||
• Hărți detaliate descărcabile cu locuri care nu sunt disponibile pe Google Maps
|
||||
• Mod outdoor cu trasee de drumeție evidențiate, locuri de campat, surse de apă, vârfuri, linii de cotă etc.
|
||||
• Căi pietonale și piste de biciclete
|
||||
• Puncte de interes precum restaurante, benzinării, hoteluri, magazine, obiective turistice și multe altele
|
||||
• Căutare după nume sau adresă sau după categoria punctului de interes
|
||||
• Navigare cu anunțuri vocale pentru mers pe jos, cu bicicleta sau cu mașina
|
||||
• Marchează-ți locurile preferate cu un singur click
|
||||
• Articole Wikipedia offline
|
||||
• Strat pentru traseul de metrou și indicații
|
||||
• Înregistrare traseu
|
||||
• Exportă și importă marcaje și trasee în formate KML, KMZ, GPX
|
||||
• Un mod întunecat pentru utilizarea nocturnă
|
||||
• Îmbunătățește datele hărții pentru toți, folosind un editor de bază încorporat
|
||||
• Suport Android Auto
|
||||
|
||||
Te rugăm să raportezi probleme ale aplicației, să sugerezi idei și să ni te alături comunității pe site-ul <b><i>comaps.app</i></b>.
|
||||
|
||||
<b>Libertatea este aici</b>
|
||||
Descoperă-ți călătoria, navighează prin lume cu confidențialitate și comunitate în prim plan!
|
||||
@@ -1 +0,0 @@
|
||||
Navigare ușoară - Descoperă mai mult din călătoria ta - Susținut de comunitate
|
||||
@@ -1 +1 @@
|
||||
CoMaps - Navighează privat
|
||||
CoMaps - Navighează liniștit
|
||||
|
||||
@@ -1 +0,0 @@
|
||||
Jednoduchá navigácia - Objav viac zo svojej cesty - Funguje vďaka komunite
|
||||
@@ -1 +0,0 @@
|
||||
CoMaps - Naviguj v súkromí
|
||||
@@ -1 +0,0 @@
|
||||
Enostavna navigacija – Odkrij več o svojem potovanju – Podprto v skupnosti
|
||||
@@ -1 +1 @@
|
||||
Једноставна навигација - Сазнајте више о свом путовању - Одржава заједница
|
||||
Једноставна навигација - Сазнајте више о свом путовању - Ради на бази заједнице
|
||||
|
||||
1
android/app/src/google/play/release-notes
Symbolic link
@@ -0,0 +1 @@
|
||||
../../fdroid/play/release-notes
|
||||
@@ -4,6 +4,7 @@ import android.content.Context;
|
||||
import android.content.res.Resources;
|
||||
import android.graphics.Color;
|
||||
import android.view.View;
|
||||
import android.widget.TextView;
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.core.content.ContextCompat;
|
||||
import app.organicmaps.sdk.Framework;
|
||||
@@ -24,11 +25,9 @@ import com.github.mikephil.charting.components.YAxis;
|
||||
import com.github.mikephil.charting.data.Entry;
|
||||
import com.github.mikephil.charting.data.LineData;
|
||||
import com.github.mikephil.charting.data.LineDataSet;
|
||||
import com.github.mikephil.charting.formatter.IAxisValueFormatter;
|
||||
import com.github.mikephil.charting.formatter.ValueFormatter;
|
||||
import com.github.mikephil.charting.highlight.Highlight;
|
||||
import com.github.mikephil.charting.listener.OnChartValueSelectedListener;
|
||||
import com.google.android.material.textview.MaterialTextView;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.Collections;
|
||||
@@ -56,10 +55,10 @@ public class ChartController implements OnChartValueSelectedListener
|
||||
private MarkerView mCurrentLocationMarkerView;
|
||||
@SuppressWarnings("NullableProblems")
|
||||
@NonNull
|
||||
private MaterialTextView mMaxAltitude;
|
||||
private TextView mMaxAltitude;
|
||||
@SuppressWarnings("NullableProblems")
|
||||
@NonNull
|
||||
private MaterialTextView mMinAltitude;
|
||||
private TextView mMinAltitude;
|
||||
@NonNull
|
||||
private final Context mContext;
|
||||
private long mTrackId = Utils.INVALID_ID;
|
||||
@@ -119,7 +118,7 @@ public class ChartController implements OnChartValueSelectedListener
|
||||
x.setPosition(XAxis.XAxisPosition.BOTTOM);
|
||||
x.setAxisLineColor(ThemeUtils.getColor(mContext, androidx.appcompat.R.attr.dividerHorizontal));
|
||||
x.setAxisLineWidth(mContext.getResources().getDimensionPixelSize(R.dimen.divider_height));
|
||||
IAxisValueFormatter xAxisFormatter = new AxisValueFormatter(mChart);
|
||||
ValueFormatter xAxisFormatter = new AxisValueFormatter(mChart);
|
||||
x.setValueFormatter(xAxisFormatter);
|
||||
|
||||
YAxis y = mChart.getAxisLeft();
|
||||
|
||||
@@ -33,6 +33,7 @@ import android.view.MotionEvent;
|
||||
import android.view.View;
|
||||
import android.view.Window;
|
||||
import android.view.WindowManager;
|
||||
import android.widget.TextView;
|
||||
import android.widget.Toast;
|
||||
import androidx.activity.result.ActivityResult;
|
||||
import androidx.activity.result.ActivityResultLauncher;
|
||||
@@ -132,8 +133,6 @@ import app.organicmaps.widget.placepage.PlacePageViewModel;
|
||||
import com.google.android.material.appbar.MaterialToolbar;
|
||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
|
||||
import com.google.android.material.floatingactionbutton.FloatingActionButton;
|
||||
import com.google.android.material.textview.MaterialTextView;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Objects;
|
||||
|
||||
@@ -720,7 +719,7 @@ public class MwmActivity extends BaseMwmFragmentActivity
|
||||
if (!TextUtils.isEmpty(appName))
|
||||
{
|
||||
setTitle(appName);
|
||||
((MaterialTextView) mPointChooser.findViewById(R.id.title)).setText(appName);
|
||||
((TextView) mPointChooser.findViewById(R.id.title)).setText(appName);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -4,6 +4,7 @@ import static android.Manifest.permission.ACCESS_COARSE_LOCATION;
|
||||
import static android.Manifest.permission.ACCESS_FINE_LOCATION;
|
||||
|
||||
import android.content.ComponentName;
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.os.Bundle;
|
||||
import android.util.Log;
|
||||
@@ -21,12 +22,14 @@ import androidx.core.view.ViewCompat;
|
||||
import androidx.core.view.WindowInsetsCompat;
|
||||
import app.organicmaps.downloader.DownloaderActivity;
|
||||
import app.organicmaps.intent.Factory;
|
||||
import app.organicmaps.sdk.display.DisplayManager;
|
||||
import app.organicmaps.sdk.location.LocationHelper;
|
||||
import app.organicmaps.sdk.util.Config;
|
||||
import app.organicmaps.sdk.util.LocationUtils;
|
||||
import app.organicmaps.sdk.util.concurrency.UiThread;
|
||||
import app.organicmaps.sdk.util.log.Logger;
|
||||
import app.organicmaps.util.SharingUtils;
|
||||
import app.organicmaps.util.ThemeUtils;
|
||||
import app.organicmaps.util.Utils;
|
||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
|
||||
import java.io.IOException;
|
||||
|
||||
@@ -17,7 +17,7 @@ import androidx.annotation.NonNull;
|
||||
import androidx.documentfile.provider.DocumentFile;
|
||||
import app.organicmaps.R;
|
||||
import app.organicmaps.sdk.util.log.Logger;
|
||||
|
||||
import app.organicmaps.util.UiUtils;
|
||||
import java.time.LocalDateTime;
|
||||
import java.time.format.DateTimeFormatter;
|
||||
import java.util.ArrayList;
|
||||
|
||||
@@ -6,6 +6,9 @@ import android.text.InputFilter;
|
||||
import android.text.TextUtils;
|
||||
import android.text.TextWatcher;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.Menu;
|
||||
import android.view.MenuInflater;
|
||||
import android.view.MenuItem;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import androidx.annotation.NonNull;
|
||||
@@ -17,7 +20,6 @@ import app.organicmaps.sdk.bookmarks.data.BookmarkManager;
|
||||
import app.organicmaps.util.InputUtils;
|
||||
import app.organicmaps.util.Utils;
|
||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
|
||||
import com.google.android.material.imageview.ShapeableImageView;
|
||||
import com.google.android.material.textfield.TextInputEditText;
|
||||
import com.google.android.material.textfield.TextInputLayout;
|
||||
import java.util.Objects;
|
||||
@@ -37,8 +39,6 @@ public class BookmarkCategorySettingsFragment extends BaseMwmToolbarFragment
|
||||
@SuppressWarnings("NullableProblems")
|
||||
@NonNull
|
||||
private TextInputEditText mEditCategoryNameView;
|
||||
@NonNull
|
||||
private ShapeableImageView mSaveView;
|
||||
|
||||
@Override
|
||||
public void onCreate(@Nullable Bundle savedInstanceState)
|
||||
@@ -85,8 +85,23 @@ public class BookmarkCategorySettingsFragment extends BaseMwmToolbarFragment
|
||||
});
|
||||
mEditDescView = root.findViewById(R.id.edit_description);
|
||||
mEditDescView.setText(mCategory.getDescription());
|
||||
mSaveView = root.findViewById(R.id.done);
|
||||
mSaveView.setOnClickListener(v -> onEditDoneClicked());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onCreateOptionsMenu(@NonNull Menu menu, MenuInflater inflater)
|
||||
{
|
||||
inflater.inflate(R.menu.menu_done, menu);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onOptionsItemSelected(MenuItem item)
|
||||
{
|
||||
if (item.getItemId() == R.id.done)
|
||||
{
|
||||
onEditDoneClicked();
|
||||
return true;
|
||||
}
|
||||
return super.onOptionsItemSelected(item);
|
||||
}
|
||||
|
||||
private void onEditDoneClicked()
|
||||
|
||||
@@ -23,8 +23,6 @@ import app.organicmaps.util.UiUtils;
|
||||
import app.organicmaps.util.Utils;
|
||||
import app.organicmaps.widget.recycler.RecyclerClickListener;
|
||||
import app.organicmaps.widget.recycler.RecyclerLongClickListener;
|
||||
|
||||
import com.google.android.material.button.MaterialButton;
|
||||
import com.google.android.material.checkbox.MaterialCheckBox;
|
||||
import com.google.android.material.imageview.ShapeableImageView;
|
||||
import com.google.android.material.textview.MaterialTextView;
|
||||
@@ -61,7 +59,7 @@ public class Holders
|
||||
public static class HeaderViewHolder extends RecyclerView.ViewHolder
|
||||
{
|
||||
@NonNull
|
||||
private final MaterialButton mButton;
|
||||
private final MaterialTextView mButton;
|
||||
@NonNull
|
||||
private final MaterialTextView mText;
|
||||
|
||||
@@ -79,7 +77,7 @@ public class Holders
|
||||
}
|
||||
|
||||
@NonNull
|
||||
public MaterialButton getButton()
|
||||
public MaterialTextView getButton()
|
||||
{
|
||||
return mButton;
|
||||
}
|
||||
|
||||
@@ -1,11 +1,5 @@
|
||||
package app.organicmaps.car.util;
|
||||
|
||||
import android.graphics.Bitmap;
|
||||
import android.graphics.BitmapFactory;
|
||||
import android.graphics.Canvas;
|
||||
import android.graphics.Color;
|
||||
import android.graphics.Paint;
|
||||
import android.graphics.Rect;
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.car.app.CarContext;
|
||||
import androidx.car.app.model.CarIcon;
|
||||
@@ -37,19 +31,18 @@ public final class RoutingHelpers
|
||||
@NonNull
|
||||
public static LaneDirection createLaneDirection(@NonNull LaneWay laneWay, boolean isRecommended)
|
||||
{
|
||||
@LaneDirection.Shape
|
||||
final int shape = switch (laneWay)
|
||||
int shape = LaneDirection.SHAPE_UNKNOWN;
|
||||
shape = switch (laneWay)
|
||||
{
|
||||
case ReverseLeft -> LaneDirection.SHAPE_U_TURN_LEFT;
|
||||
case SharpLeft -> LaneDirection.SHAPE_SHARP_LEFT;
|
||||
case Left -> LaneDirection.SHAPE_NORMAL_LEFT;
|
||||
case MergeToLeft, SlightLeft -> LaneDirection.SHAPE_SLIGHT_LEFT;
|
||||
case Through -> LaneDirection.SHAPE_STRAIGHT;
|
||||
case SlightRight, MergeToRight -> LaneDirection.SHAPE_SLIGHT_RIGHT;
|
||||
case Right -> LaneDirection.SHAPE_NORMAL_RIGHT;
|
||||
case SharpRight -> LaneDirection.SHAPE_SHARP_RIGHT;
|
||||
case ReverseRight -> LaneDirection.SHAPE_U_TURN_RIGHT;
|
||||
default -> LaneDirection.SHAPE_UNKNOWN;
|
||||
case REVERSE -> LaneDirection.SHAPE_U_TURN_LEFT;
|
||||
case SHARP_LEFT -> LaneDirection.SHAPE_SHARP_LEFT;
|
||||
case LEFT -> LaneDirection.SHAPE_NORMAL_LEFT;
|
||||
case SLIGHT_LEFT, MERGE_TO_LEFT -> LaneDirection.SHAPE_SLIGHT_LEFT;
|
||||
case SLIGHT_RIGHT, MERGE_TO_RIGHT -> LaneDirection.SHAPE_SLIGHT_RIGHT;
|
||||
case THROUGH -> LaneDirection.SHAPE_STRAIGHT;
|
||||
case RIGHT -> LaneDirection.SHAPE_NORMAL_RIGHT;
|
||||
case SHARP_RIGHT -> LaneDirection.SHAPE_SHARP_RIGHT;
|
||||
default -> shape;
|
||||
};
|
||||
|
||||
return LaneDirection.create(shape, isRecommended);
|
||||
@@ -80,32 +73,7 @@ public final class RoutingHelpers
|
||||
final Maneuver.Builder builder = new Maneuver.Builder(maneuverType);
|
||||
if (maneuverType == Maneuver.TYPE_ROUNDABOUT_ENTER_AND_EXIT_CCW)
|
||||
builder.setRoundaboutExitNumber(roundaboutExitNum > 0 ? roundaboutExitNum : 1);
|
||||
builder.setIcon(new CarIcon.Builder(createManeuverIcon(context, carDirection, roundaboutExitNum)).build());
|
||||
builder.setIcon(new CarIcon.Builder(IconCompat.createWithResource(context, carDirection.getTurnRes())).build());
|
||||
return builder.build();
|
||||
}
|
||||
|
||||
@NonNull
|
||||
private static IconCompat createManeuverIcon(@NonNull final CarContext context, @NonNull CarDirection carDirection, int roundaboutExitNum)
|
||||
{
|
||||
if (!CarDirection.isRoundAbout(carDirection) || roundaboutExitNum == 0)
|
||||
{
|
||||
return IconCompat.createWithResource(context, carDirection.getTurnRes());
|
||||
}
|
||||
Bitmap bitmapImmutable = BitmapFactory.decodeResource(context.getResources(), carDirection.getTurnRes());
|
||||
Bitmap bitmap = bitmapImmutable.copy(Bitmap.Config.ARGB_8888, true);
|
||||
Canvas canvas = new Canvas(bitmap);
|
||||
Paint paint = new Paint();
|
||||
paint.setColor(Color.WHITE);
|
||||
paint.setTextAlign(Paint.Align.LEFT);
|
||||
paint.setFakeBoldText(true);
|
||||
paint.setTextSize(24);
|
||||
paint.setAntiAlias(true);
|
||||
String digit = String.valueOf(roundaboutExitNum);
|
||||
Rect bounds = new Rect();
|
||||
paint.getTextBounds(digit, 0, 1, bounds);
|
||||
float cx = canvas.getWidth() / 2f - bounds.exactCenterX();
|
||||
float cy = canvas.getHeight() / 2f - bounds.exactCenterY();
|
||||
canvas.drawText(digit, cx, cy, paint);
|
||||
return IconCompat.createWithBitmap(bitmap);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -13,9 +13,9 @@ import androidx.car.app.navigation.model.TravelEstimate;
|
||||
import androidx.car.app.navigation.model.Trip;
|
||||
import androidx.core.graphics.drawable.IconCompat;
|
||||
import app.organicmaps.sdk.bookmarks.data.MapObject;
|
||||
import app.organicmaps.sdk.routing.LaneInfo;
|
||||
import app.organicmaps.sdk.routing.LaneWay;
|
||||
import app.organicmaps.sdk.routing.RoutingInfo;
|
||||
import app.organicmaps.sdk.routing.SingleLaneInfo;
|
||||
import app.organicmaps.sdk.util.Distance;
|
||||
import app.organicmaps.util.Graphics;
|
||||
import app.organicmaps.widget.LanesDrawable;
|
||||
@@ -69,12 +69,11 @@ public final class RoutingUtils
|
||||
builder.setManeuver(RoutingHelpers.createManeuver(context, info.carDirection, info.exitNum));
|
||||
if (info.lanes != null)
|
||||
{
|
||||
for (final LaneInfo laneInfo : info.lanes)
|
||||
for (final SingleLaneInfo laneInfo : info.lanes)
|
||||
{
|
||||
final Lane.Builder laneBuilder = new Lane.Builder();
|
||||
for (final LaneWay laneWay : laneInfo.mLaneWays)
|
||||
laneBuilder.addDirection(
|
||||
RoutingHelpers.createLaneDirection(laneWay, /* isRecommended */ laneWay == laneInfo.mActiveLaneWay));
|
||||
for (final LaneWay laneWay : laneInfo.mLane)
|
||||
laneBuilder.addDirection(RoutingHelpers.createLaneDirection(laneWay, laneInfo.mIsActive));
|
||||
builder.addLane(laneBuilder.build());
|
||||
}
|
||||
final LanesDrawable lanesDrawable = new LanesDrawable(context, info.lanes);
|
||||
|
||||
@@ -378,16 +378,14 @@ class DownloaderAdapter extends RecyclerView.Adapter<DownloaderAdapter.ViewHolde
|
||||
case CountryItem.STATUS_DOWNLOADABLE, CountryItem.STATUS_PARTLY ->
|
||||
{
|
||||
if (clickOnStatus)
|
||||
{
|
||||
if (mItem.isExpandable())
|
||||
goDeeper(mItem, true);
|
||||
else
|
||||
onDownloadActionSelected(mItem, DownloaderAdapter.this);
|
||||
}
|
||||
onDownloadActionSelected(mItem, DownloaderAdapter.this);
|
||||
else
|
||||
processLongClick();
|
||||
}
|
||||
case CountryItem.STATUS_FAILED -> MapManagerHelper.warn3gAndRetry(mActivity, mItem.id, null);
|
||||
case CountryItem.STATUS_FAILED ->
|
||||
{
|
||||
MapManagerHelper.warn3gAndRetry(mActivity, mItem.id, null);
|
||||
}
|
||||
case CountryItem.STATUS_UPDATABLE ->
|
||||
MapManagerHelper.warnOn3gUpdate(mActivity, mItem.id, () -> MapManagerHelper.startUpdate(mItem.id));
|
||||
default -> throw new IllegalArgumentException("Inappropriate item status: " + mItem.status);
|
||||
|
||||
@@ -33,8 +33,6 @@ import app.organicmaps.sdk.util.Utils;
|
||||
import app.organicmaps.util.Graphics;
|
||||
import app.organicmaps.util.InputUtils;
|
||||
import app.organicmaps.util.UiUtils;
|
||||
|
||||
import com.google.android.material.button.MaterialButton;
|
||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
|
||||
import com.google.android.material.imageview.ShapeableImageView;
|
||||
import com.google.android.material.textfield.TextInputEditText;
|
||||
@@ -90,8 +88,8 @@ public class EditorFragment extends BaseMwmFragment implements View.OnClickListe
|
||||
|
||||
private MultilanguageAdapter mNamesAdapter;
|
||||
private MaterialTextView mNamesCaption;
|
||||
private MaterialButton mAddLanguage;
|
||||
private MaterialButton mMoreLanguages;
|
||||
private MaterialTextView mAddLanguage;
|
||||
private MaterialTextView mMoreLanguages;
|
||||
|
||||
private MaterialTextView mStreet;
|
||||
private TextInputEditText mHouseNumber;
|
||||
@@ -99,7 +97,7 @@ public class EditorFragment extends BaseMwmFragment implements View.OnClickListe
|
||||
|
||||
// Define Metadata entries, that have more tricky logic, separately.
|
||||
private MaterialTextView mPhone;
|
||||
private MaterialButton mEditPhoneLink;
|
||||
private MaterialTextView mEditPhoneLink;
|
||||
private MaterialTextView mCuisine;
|
||||
private SwitchCompat mWifi;
|
||||
private MaterialTextView mSelfService;
|
||||
@@ -136,7 +134,7 @@ public class EditorFragment extends BaseMwmFragment implements View.OnClickListe
|
||||
private TextInputEditText mDescription;
|
||||
private final Map<Metadata.MetadataType, View> mDetailsBlocks = new HashMap<>();
|
||||
private final Map<Metadata.MetadataType, View> mSocialMediaBlocks = new HashMap<>();
|
||||
private MaterialButton mReset;
|
||||
private MaterialTextView mReset;
|
||||
|
||||
private EditorHostFragment mParent;
|
||||
|
||||
@@ -470,7 +468,7 @@ public class EditorFragment extends BaseMwmFragment implements View.OnClickListe
|
||||
View levelBlock = initBlock(view, Metadata.MetadataType.FMD_LEVEL, R.id.block_level, R.drawable.ic_level_white,
|
||||
R.string.editor_level, InputType.TYPE_CLASS_NUMBER);
|
||||
View fediverseContactBlock =
|
||||
initBlock(view, Metadata.MetadataType.FMD_CONTACT_FEDIVERSE, R.id.block_fediverse, R.drawable.ic_mastodon,
|
||||
initBlock(view, Metadata.MetadataType.FMD_CONTACT_FEDIVERSE, R.id.block_fediverse, R.drawable.ic_mastodon_white,
|
||||
R.string.mastodon, InputType.TYPE_TEXT_VARIATION_URI);
|
||||
View facebookContactBlock =
|
||||
initBlock(view, Metadata.MetadataType.FMD_CONTACT_FACEBOOK, R.id.block_facebook, R.drawable.ic_facebook_white,
|
||||
@@ -487,7 +485,7 @@ public class EditorFragment extends BaseMwmFragment implements View.OnClickListe
|
||||
initBlock(view, Metadata.MetadataType.FMD_CONTACT_LINE, R.id.block_line, R.drawable.ic_line_white,
|
||||
R.string.editor_line_social_network, InputType.TYPE_TEXT_VARIATION_URI);
|
||||
View blueskyContactBlock =
|
||||
initBlock(view, Metadata.MetadataType.FMD_CONTACT_BLUESKY, R.id.block_bluesky, R.drawable.ic_bluesky,
|
||||
initBlock(view, Metadata.MetadataType.FMD_CONTACT_BLUESKY, R.id.block_bluesky, R.drawable.ic_bluesky_white,
|
||||
R.string.bluesky, InputType.TYPE_TEXT_VARIATION_URI);
|
||||
View operatorBlock = initBlock(view, Metadata.MetadataType.FMD_OPERATOR, R.id.block_operator,
|
||||
R.drawable.ic_operator, R.string.editor_operator, 0);
|
||||
|
||||
@@ -66,9 +66,12 @@ public class FeatureCategoryAdapter extends RecyclerView.Adapter<RecyclerView.Vi
|
||||
case TYPE_FOOTER ->
|
||||
{
|
||||
return new FooterViewHolder(inflater.inflate(R.layout.item_feature_category_footer, parent, false),
|
||||
mFragment);
|
||||
(FooterListener) mFragment);
|
||||
}
|
||||
default ->
|
||||
{
|
||||
throw new IllegalArgumentException("Unsupported viewType: " + viewType);
|
||||
}
|
||||
default -> throw new IllegalArgumentException("Unsupported viewType: " + viewType);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -4,6 +4,7 @@ import static app.organicmaps.sdk.util.Utils.getLocalizedFeatureType;
|
||||
|
||||
import android.content.Intent;
|
||||
import android.os.Bundle;
|
||||
import android.text.TextUtils;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
@@ -14,6 +15,7 @@ import androidx.annotation.Nullable;
|
||||
import app.organicmaps.MwmApplication;
|
||||
import app.organicmaps.R;
|
||||
import app.organicmaps.base.BaseMwmRecyclerFragment;
|
||||
import app.organicmaps.dialog.EditTextDialogFragment;
|
||||
import app.organicmaps.sdk.Framework;
|
||||
import app.organicmaps.sdk.editor.Editor;
|
||||
import app.organicmaps.sdk.editor.OsmOAuth;
|
||||
|
||||
@@ -9,7 +9,6 @@ import android.text.format.DateFormat;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.widget.Button;
|
||||
import android.widget.TextView;
|
||||
import android.widget.TimePicker;
|
||||
import androidx.annotation.IntRange;
|
||||
import androidx.annotation.NonNull;
|
||||
@@ -134,7 +133,7 @@ public class HoursMinutesPickerFragment extends BaseMwmDialogFragment
|
||||
if (id != 0)
|
||||
{
|
||||
mPickerHoursLabel = mPicker.findViewById(id);
|
||||
if (!(mPickerHoursLabel instanceof TextView))
|
||||
if (!(mPickerHoursLabel instanceof MaterialTextView))
|
||||
mPickerHoursLabel = null;
|
||||
}
|
||||
|
||||
|
||||
@@ -6,6 +6,7 @@ import android.os.Bundle;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.widget.ProgressBar;
|
||||
import android.widget.ScrollView;
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
@@ -14,16 +15,24 @@ import app.organicmaps.R;
|
||||
import app.organicmaps.base.BaseMwmToolbarFragment;
|
||||
import app.organicmaps.sdk.editor.OsmOAuth;
|
||||
import app.organicmaps.sdk.util.Constants;
|
||||
import app.organicmaps.sdk.util.DateUtils;
|
||||
import app.organicmaps.sdk.util.concurrency.ThreadPool;
|
||||
import app.organicmaps.sdk.util.concurrency.UiThread;
|
||||
import app.organicmaps.util.InputUtils;
|
||||
import app.organicmaps.util.UiUtils;
|
||||
import app.organicmaps.util.Utils;
|
||||
import app.organicmaps.util.WindowInsetUtils.ScrollableContentInsetsListener;
|
||||
import com.google.android.material.button.MaterialButton;
|
||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
|
||||
import com.google.android.material.textfield.TextInputEditText;
|
||||
|
||||
public class OsmLoginFragment extends BaseMwmToolbarFragment
|
||||
{
|
||||
private ProgressBar mProgress;
|
||||
private MaterialButton mLoginButton;
|
||||
private MaterialButton mLostPasswordButton;
|
||||
private TextInputEditText mLoginInput;
|
||||
private TextInputEditText mPasswordInput;
|
||||
|
||||
@Nullable
|
||||
@Override
|
||||
@@ -37,10 +46,28 @@ public class OsmLoginFragment extends BaseMwmToolbarFragment
|
||||
{
|
||||
super.onViewCreated(view, savedInstanceState);
|
||||
getToolbarController().setTitle(R.string.login);
|
||||
mLoginInput = view.findViewById(R.id.osm_username);
|
||||
mPasswordInput = view.findViewById(R.id.osm_password);
|
||||
mLoginButton = view.findViewById(R.id.login);
|
||||
mLostPasswordButton = view.findViewById(R.id.lost_password);
|
||||
MaterialButton registerButton = view.findViewById(R.id.register);
|
||||
registerButton.setOnClickListener((v) -> Utils.openUrl(requireActivity(), Constants.Url.OSM_REGISTER));
|
||||
mProgress = view.findViewById(R.id.osm_login_progress);
|
||||
|
||||
// TODO(@pastk): remove unused flow with users entering credentials into app's form
|
||||
// Hide login and password inputs and Forgot password button
|
||||
UiUtils.hide(view.findViewById(R.id.osm_username_container), view.findViewById(R.id.osm_password_container),
|
||||
mLostPasswordButton);
|
||||
|
||||
mLoginButton.setOnClickListener((v) -> loginWithBrowser());
|
||||
/* login via in-app form
|
||||
else
|
||||
{
|
||||
mLoginButton.setOnClickListener((v) -> login());
|
||||
mLostPasswordButton.setOnClickListener((v) -> Utils.openUrl(requireActivity(),
|
||||
Constants.Url.OSM_RECOVER_PASSWORD));
|
||||
}
|
||||
*/
|
||||
|
||||
String code = readOAuth2CodeFromArguments();
|
||||
if (code != null && !code.isEmpty())
|
||||
@@ -59,17 +86,42 @@ public class OsmLoginFragment extends BaseMwmToolbarFragment
|
||||
return arguments.getString(OsmLoginActivity.EXTRA_OAUTH2CODE);
|
||||
}
|
||||
|
||||
private void login()
|
||||
{
|
||||
InputUtils.hideKeyboard(mLoginInput);
|
||||
final String username = mLoginInput.getText().toString().trim();
|
||||
final String password = mPasswordInput.getText().toString();
|
||||
enableInput(false);
|
||||
UiUtils.show(mProgress);
|
||||
mLoginButton.setText("");
|
||||
|
||||
ThreadPool.getWorker().execute(() -> {
|
||||
final String oauthToken = OsmOAuth.nativeAuthWithPassword(username, password);
|
||||
final String username1 = (oauthToken == null) ? null : OsmOAuth.nativeGetOsmUsername(oauthToken);
|
||||
UiThread.run(() -> processAuth(oauthToken, username1));
|
||||
});
|
||||
}
|
||||
|
||||
private void loginWithBrowser()
|
||||
{
|
||||
Utils.openUri(requireContext(), Uri.parse(OsmOAuth.nativeGetOAuth2Url()), R.string.browser_not_available);
|
||||
}
|
||||
|
||||
private void enableInput(boolean enable)
|
||||
{
|
||||
mPasswordInput.setEnabled(enable);
|
||||
mLoginInput.setEnabled(enable);
|
||||
mLoginButton.setEnabled(enable);
|
||||
mLostPasswordButton.setEnabled(enable);
|
||||
}
|
||||
|
||||
private void processAuth(String oauthToken, String username)
|
||||
{
|
||||
if (!isAdded())
|
||||
return;
|
||||
|
||||
mLoginButton.setEnabled(true);
|
||||
enableInput(true);
|
||||
UiUtils.hide(mProgress);
|
||||
mLoginButton.setText(R.string.login_osm);
|
||||
if (oauthToken == null)
|
||||
onAuthFail();
|
||||
|
||||
@@ -17,6 +17,7 @@ import app.organicmaps.BuildConfig;
|
||||
import app.organicmaps.R;
|
||||
import app.organicmaps.base.BaseMwmFragment;
|
||||
import app.organicmaps.sdk.Framework;
|
||||
import app.organicmaps.sdk.util.Config;
|
||||
import app.organicmaps.sdk.util.Constants;
|
||||
import app.organicmaps.sdk.util.DateUtils;
|
||||
import app.organicmaps.util.Graphics;
|
||||
@@ -57,17 +58,18 @@ public class HelpFragment extends BaseMwmFragment implements View.OnClickListene
|
||||
Linkify.addLinks(osmPresentationView, Linkify.WEB_URLS);
|
||||
}
|
||||
|
||||
setupItem(R.id.faq, true, root);
|
||||
setupItem(R.id.news, true, root);
|
||||
setupItem(R.id.web, true, root);
|
||||
setupItem(R.id.code_repo, true, root);
|
||||
setupItem(R.id.mastodon, true, root);
|
||||
setupItem(R.id.matrix, true, root);
|
||||
setupItem(R.id.lemmy, true, root);
|
||||
setupItem(R.id.bluesky, true, root);
|
||||
setupItem(R.id.pixelfed, true, root);
|
||||
setupItem(R.id.openstreetmap, true, root);
|
||||
setupItem(R.id.email, true, root);
|
||||
setupItem(R.id.code_repo, false, root);
|
||||
setupItem(R.id.telegram, false, root);
|
||||
setupItem(R.id.instagram, false, root);
|
||||
setupItem(R.id.facebook, false, root);
|
||||
// setupItem(R.id.twitter, true, root);
|
||||
setupItem(R.id.matrix, true, root);
|
||||
setupItem(R.id.mastodon, false, root);
|
||||
setupItem(R.id.openstreetmap, true, root);
|
||||
setupItem(R.id.faq, true, root);
|
||||
setupItem(R.id.report, isLandscape, root);
|
||||
setupItem(R.id.copyright, false, root);
|
||||
|
||||
@@ -118,16 +120,18 @@ public class HelpFragment extends BaseMwmFragment implements View.OnClickListene
|
||||
Utils.sendTo(requireContext(), BuildConfig.SUPPORT_MAIL, getString(R.string.project_name));
|
||||
else if (id == R.id.code_repo)
|
||||
Utils.openUrl(requireActivity(), Constants.Url.CODE_REPO);
|
||||
else if (id == R.id.mastodon)
|
||||
Utils.openUrl(requireActivity(), Constants.Url.MASTODON);
|
||||
else if (id == R.id.telegram)
|
||||
Utils.openUrl(requireActivity(), getString(R.string.telegram_url));
|
||||
else if (id == R.id.instagram)
|
||||
Utils.openUrl(requireActivity(), getString(R.string.instagram_url));
|
||||
else if (id == R.id.facebook)
|
||||
Utils.showFacebookPage(requireActivity());
|
||||
// else if (id == R.id.twitter)
|
||||
// Utils.openUrl(requireActivity(), Constants.Url.TWITTER);
|
||||
else if (id == R.id.matrix)
|
||||
Utils.openUrl(requireActivity(), Constants.Url.MATRIX);
|
||||
else if (id == R.id.lemmy)
|
||||
Utils.openUrl(requireActivity(), Constants.Url.LEMMY);
|
||||
else if (id == R.id.bluesky)
|
||||
Utils.openUrl(requireActivity(), Constants.Url.BLUESKY);
|
||||
else if (id == R.id.pixelfed)
|
||||
Utils.openUrl(requireActivity(), Constants.Url.PIXELFED);
|
||||
else if (id == R.id.mastodon)
|
||||
Utils.openUrl(requireActivity(), Constants.Url.MASTODON);
|
||||
else if (id == R.id.openstreetmap)
|
||||
Utils.openUrl(requireActivity(), getString(R.string.osm_wiki_about_url));
|
||||
else if (id == R.id.faq)
|
||||
|
||||
@@ -2,12 +2,10 @@ package app.organicmaps.maplayer;
|
||||
|
||||
import android.view.View;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.TextView;
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
|
||||
import com.google.android.material.textview.MaterialTextView;
|
||||
|
||||
import app.organicmaps.R;
|
||||
import app.organicmaps.adapter.OnItemClickListener;
|
||||
|
||||
@@ -16,7 +14,7 @@ class LayerHolder extends RecyclerView.ViewHolder
|
||||
@NonNull
|
||||
final ImageView mButton;
|
||||
@NonNull
|
||||
final MaterialTextView mTitle;
|
||||
final TextView mTitle;
|
||||
@NonNull
|
||||
final View mNewMarker;
|
||||
@Nullable
|
||||
|
||||
@@ -38,6 +38,7 @@ import app.organicmaps.sdk.routing.RoutingController;
|
||||
import app.organicmaps.sdk.util.Config;
|
||||
import app.organicmaps.util.ThemeUtils;
|
||||
import app.organicmaps.util.UiUtils;
|
||||
import app.organicmaps.util.Utils;
|
||||
import app.organicmaps.util.WindowInsetUtils;
|
||||
import app.organicmaps.widget.menu.MyPositionButton;
|
||||
import app.organicmaps.widget.placepage.PlacePageViewModel;
|
||||
|
||||
@@ -31,6 +31,7 @@ import app.organicmaps.widget.LanesView;
|
||||
import app.organicmaps.widget.SpeedLimitView;
|
||||
import app.organicmaps.widget.menu.NavMenu;
|
||||
import com.google.android.material.bottomsheet.BottomSheetBehavior;
|
||||
import com.google.android.material.imageview.ShapeableImageView;
|
||||
import com.google.android.material.textview.MaterialTextView;
|
||||
|
||||
public class NavigationController implements TrafficManager.TrafficCallback, NavMenu.NavMenuListener
|
||||
|
||||
@@ -20,7 +20,9 @@ import android.text.style.StyleSpan;
|
||||
import android.text.style.TypefaceSpan;
|
||||
import android.view.View;
|
||||
import android.widget.Button;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.ScrollView;
|
||||
import android.widget.TextView;
|
||||
import androidx.annotation.IdRes;
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
@@ -68,13 +70,13 @@ final class RoutingBottomMenuController implements View.OnClickListener
|
||||
@NonNull
|
||||
private final MaterialButton mStart;
|
||||
@NonNull
|
||||
private final ShapeableImageView mAltitudeChart;
|
||||
private final ImageView mAltitudeChart;
|
||||
@NonNull
|
||||
private final MaterialTextView mTime;
|
||||
@NonNull
|
||||
private final MaterialTextView mAltitudeDifference;
|
||||
@NonNull
|
||||
private final MaterialTextView mTimeVehicle;
|
||||
private final TextView mTimeVehicle;
|
||||
@Nullable
|
||||
private final MaterialTextView mArrival;
|
||||
@NonNull
|
||||
@@ -100,9 +102,9 @@ final class RoutingBottomMenuController implements View.OnClickListener
|
||||
View transitFrame = getViewById(activity, frame, R.id.transit_panel);
|
||||
MaterialTextView error = (MaterialTextView) getViewById(activity, frame, R.id.error);
|
||||
MaterialButton start = (MaterialButton) getViewById(activity, frame, R.id.start);
|
||||
ShapeableImageView altitudeChart = (ShapeableImageView) getViewById(activity, frame, R.id.altitude_chart);
|
||||
ImageView altitudeChart = (ImageView) getViewById(activity, frame, R.id.altitude_chart);
|
||||
MaterialTextView time = (MaterialTextView) getViewById(activity, frame, R.id.time);
|
||||
MaterialTextView timeVehicle = (MaterialTextView) getViewById(activity, frame, R.id.time_vehicle);
|
||||
TextView timeVehicle = (TextView) getViewById(activity, frame, R.id.time_vehicle);
|
||||
MaterialTextView altitudeDifference = (MaterialTextView) getViewById(activity, frame, R.id.altitude_difference);
|
||||
MaterialTextView arrival = (MaterialTextView) getViewById(activity, frame, R.id.arrival);
|
||||
View actionFrame = getViewById(activity, frame, R.id.routing_action_frame);
|
||||
@@ -122,8 +124,8 @@ final class RoutingBottomMenuController implements View.OnClickListener
|
||||
private RoutingBottomMenuController(@NonNull Activity context, @NonNull View altitudeChartFrame,
|
||||
@NonNull View timeElevationLine, @NonNull View transitFrame,
|
||||
@NonNull MaterialTextView error, @NonNull MaterialButton start,
|
||||
@NonNull ShapeableImageView altitudeChart, @NonNull MaterialTextView time,
|
||||
@NonNull MaterialTextView altitudeDifference, @NonNull MaterialTextView timeVehicle,
|
||||
@NonNull ImageView altitudeChart, @NonNull MaterialTextView time,
|
||||
@NonNull MaterialTextView altitudeDifference, @NonNull TextView timeVehicle,
|
||||
@Nullable MaterialTextView arrival, @NonNull View actionFrame,
|
||||
@Nullable RoutingBottomMenuListener listener)
|
||||
{
|
||||
|
||||
@@ -16,6 +16,7 @@ import androidx.fragment.app.FragmentManager;
|
||||
import app.organicmaps.R;
|
||||
import app.organicmaps.downloader.MapManagerHelper;
|
||||
import app.organicmaps.sdk.downloader.CountryItem;
|
||||
import app.organicmaps.sdk.downloader.MapManager;
|
||||
import app.organicmaps.util.UiUtils;
|
||||
import com.google.android.material.textview.MaterialTextView;
|
||||
|
||||
|
||||
@@ -6,15 +6,13 @@ import android.os.Bundle;
|
||||
import android.view.View;
|
||||
import android.widget.CompoundButton;
|
||||
import android.widget.RadioGroup;
|
||||
import android.widget.TextView;
|
||||
import androidx.activity.result.ActivityResultLauncher;
|
||||
import androidx.annotation.DrawableRes;
|
||||
import androidx.annotation.IdRes;
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.core.view.ViewCompat;
|
||||
import androidx.core.view.WindowInsetsCompat;
|
||||
|
||||
import com.google.android.material.textview.MaterialTextView;
|
||||
|
||||
import app.organicmaps.MwmApplication;
|
||||
import app.organicmaps.R;
|
||||
import app.organicmaps.sdk.Framework;
|
||||
@@ -321,7 +319,7 @@ public class RoutingPlanController extends ToolbarController
|
||||
UiUtils.show(mDrivingOptionsBtnContainer);
|
||||
boolean hasAnyOptions = RoutingOptions.hasAnyOptions() && !isRulerType();
|
||||
UiUtils.showIf(hasAnyOptions, mDrivingOptionsImage);
|
||||
MaterialTextView title = mDrivingOptionsBtnContainer.findViewById(R.id.driving_options_btn_title);
|
||||
TextView title = mDrivingOptionsBtnContainer.findViewById(R.id.driving_options_btn_title);
|
||||
title.setText(hasAnyOptions ? R.string.change_driving_options_btn : R.string.define_to_avoid_btn);
|
||||
}
|
||||
|
||||
|
||||
@@ -8,15 +8,13 @@ import android.content.res.Resources;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.widget.TextView;
|
||||
import androidx.annotation.DrawableRes;
|
||||
import androidx.annotation.IntDef;
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.StringRes;
|
||||
import androidx.fragment.app.Fragment;
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
|
||||
import com.google.android.material.textview.MaterialTextView;
|
||||
|
||||
import app.organicmaps.R;
|
||||
import app.organicmaps.sdk.search.DisplayedCategories;
|
||||
import app.organicmaps.sdk.util.Language;
|
||||
@@ -114,7 +112,7 @@ class CategoriesAdapter extends RecyclerView.Adapter<CategoriesAdapter.ViewHolde
|
||||
if (viewType == ViewType.CATEGORY)
|
||||
{
|
||||
view = mInflater.inflate(R.layout.item_search_category, parent, false);
|
||||
viewHolder = new ViewHolder(view, (MaterialTextView) view);
|
||||
viewHolder = new ViewHolder(view, (TextView) view);
|
||||
}
|
||||
else
|
||||
{
|
||||
@@ -140,7 +138,7 @@ class CategoriesAdapter extends RecyclerView.Adapter<CategoriesAdapter.ViewHolde
|
||||
class ViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener
|
||||
{
|
||||
@NonNull
|
||||
private final MaterialTextView mTitle;
|
||||
private final TextView mTitle;
|
||||
@NonNull
|
||||
private final View mView;
|
||||
|
||||
@@ -168,7 +166,7 @@ class CategoriesAdapter extends RecyclerView.Adapter<CategoriesAdapter.ViewHolde
|
||||
return mEnglishResources.getString(categoryId);
|
||||
}
|
||||
|
||||
ViewHolder(@NonNull View v, @NonNull MaterialTextView tv)
|
||||
ViewHolder(@NonNull View v, @NonNull TextView tv)
|
||||
{
|
||||
super(v);
|
||||
mView = v;
|
||||
|
||||
@@ -5,14 +5,12 @@ import android.content.res.Resources;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.widget.TextView;
|
||||
import androidx.annotation.AttrRes;
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.core.content.ContextCompat;
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
|
||||
import com.google.android.material.textview.MaterialTextView;
|
||||
|
||||
import app.organicmaps.R;
|
||||
import app.organicmaps.sdk.search.SearchResult;
|
||||
import app.organicmaps.util.Graphics;
|
||||
@@ -44,11 +42,11 @@ class SearchAdapter extends RecyclerView.Adapter<SearchAdapter.SearchDataViewHol
|
||||
BaseResultViewHolder(@NonNull View view)
|
||||
{
|
||||
super(view);
|
||||
if (view instanceof MaterialTextView)
|
||||
if (view instanceof TextView)
|
||||
{
|
||||
int tintAttr = getTintAttr();
|
||||
if (tintAttr != 0)
|
||||
Graphics.tint((MaterialTextView) view, tintAttr);
|
||||
Graphics.tint((TextView) view, tintAttr);
|
||||
}
|
||||
view.setOnClickListener(v -> processClick(mResult, mOrder));
|
||||
}
|
||||
@@ -58,7 +56,7 @@ class SearchAdapter extends RecyclerView.Adapter<SearchAdapter.SearchDataViewHol
|
||||
{
|
||||
mResult = result;
|
||||
mOrder = order;
|
||||
final MaterialTextView titleView = getTitleView();
|
||||
final TextView titleView = getTitleView();
|
||||
|
||||
if (titleView != null)
|
||||
titleView.setText(mResult.getFormattedTitle(titleView.getContext()));
|
||||
@@ -70,7 +68,7 @@ class SearchAdapter extends RecyclerView.Adapter<SearchAdapter.SearchDataViewHol
|
||||
return androidx.appcompat.R.attr.colorAccent;
|
||||
}
|
||||
|
||||
abstract MaterialTextView getTitleView();
|
||||
abstract TextView getTitleView();
|
||||
|
||||
abstract void processClick(SearchResult result, int order);
|
||||
}
|
||||
@@ -83,9 +81,9 @@ class SearchAdapter extends RecyclerView.Adapter<SearchAdapter.SearchDataViewHol
|
||||
}
|
||||
|
||||
@Override
|
||||
MaterialTextView getTitleView()
|
||||
TextView getTitleView()
|
||||
{
|
||||
return (MaterialTextView) itemView;
|
||||
return (TextView) itemView;
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -100,15 +98,15 @@ class SearchAdapter extends RecyclerView.Adapter<SearchAdapter.SearchDataViewHol
|
||||
@NonNull
|
||||
final View mFrame;
|
||||
@NonNull
|
||||
final MaterialTextView mName;
|
||||
final TextView mName;
|
||||
@NonNull
|
||||
final MaterialTextView mOpen;
|
||||
final TextView mOpen;
|
||||
@NonNull
|
||||
final MaterialTextView mDescription;
|
||||
final TextView mDescription;
|
||||
@NonNull
|
||||
final MaterialTextView mRegion;
|
||||
final TextView mRegion;
|
||||
@NonNull
|
||||
final MaterialTextView mDistance;
|
||||
final TextView mDistance;
|
||||
|
||||
@Override
|
||||
int getTintAttr()
|
||||
@@ -128,7 +126,7 @@ class SearchAdapter extends RecyclerView.Adapter<SearchAdapter.SearchDataViewHol
|
||||
}
|
||||
|
||||
@Override
|
||||
MaterialTextView getTitleView()
|
||||
TextView getTitleView()
|
||||
{
|
||||
return mName;
|
||||
}
|
||||
|
||||
@@ -3,11 +3,9 @@ package app.organicmaps.search;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.widget.TextView;
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
|
||||
import com.google.android.material.textview.MaterialTextView;
|
||||
|
||||
import app.organicmaps.MwmApplication;
|
||||
import app.organicmaps.R;
|
||||
import app.organicmaps.sdk.routing.RoutingController;
|
||||
@@ -27,12 +25,12 @@ class SearchHistoryAdapter extends RecyclerView.Adapter<SearchHistoryAdapter.Vie
|
||||
|
||||
public static class ViewHolder extends RecyclerView.ViewHolder
|
||||
{
|
||||
private final MaterialTextView mText;
|
||||
private final TextView mText;
|
||||
|
||||
public ViewHolder(View itemView)
|
||||
{
|
||||
super(itemView);
|
||||
mText = (MaterialTextView) itemView;
|
||||
mText = (TextView) itemView;
|
||||
Graphics.tint(mText);
|
||||
}
|
||||
}
|
||||
|
||||