CleanUp, Opti, Svg, ...
| Before Width: | Height: | Size: 6.4 MiB After Width: | Height: | Size: 6.4 MiB | 
| Before Width: | Height: | Size: 6.4 MiB After Width: | Height: | Size: 6.4 MiB | 
| Before Width: | Height: | Size: 6.4 MiB | 
| Before Width: | Height: | Size: 6.4 MiB After Width: | Height: | Size: 6.4 MiB | 
| Before Width: | Height: | Size: 6.6 MiB | 
| Before Width: | Height: | Size: 6.6 MiB After Width: | Height: | Size: 6.5 MiB | 
| @@ -37,7 +37,7 @@ class MainActivity : AppCompatActivity() { | ||||
|     override fun onOptionsItemSelected(item: MenuItem): Boolean { | ||||
|         val d = when (item.itemId) { | ||||
|             R.id.action_edit -> EditActivity::class.java | ||||
|             R.id.action_stats -> StatActivity::class.java | ||||
|             R.id.action_stats -> StatsActivity::class.java | ||||
|             R.id.action_settings -> SettingsActivity::class.java | ||||
|             else -> throw Exception("Non Existent Menu Item") | ||||
|         } | ||||
|   | ||||
| @@ -4,7 +4,6 @@ import android.os.Bundle | ||||
| import android.view.MenuItem | ||||
| import androidx.appcompat.app.AppCompatActivity | ||||
| import androidx.fragment.app.Fragment | ||||
| import androidx.preference.PreferenceManager | ||||
| import androidx.recyclerview.widget.LinearLayoutManager | ||||
| import androidx.recyclerview.widget.RecyclerView | ||||
| import androidx.viewpager2.adapter.FragmentStateAdapter | ||||
| @@ -12,18 +11,16 @@ import androidx.viewpager2.widget.ViewPager2 | ||||
| import com.google.android.material.tabs.TabLayoutMediator | ||||
| import net.helcel.beans.R | ||||
| import net.helcel.beans.activity.adapter.StatsListAdapter | ||||
| import net.helcel.beans.countries.GeoLoc.LocType | ||||
| import net.helcel.beans.databinding.ActivityStatBinding | ||||
| import net.helcel.beans.helper.Settings | ||||
| import net.helcel.beans.helper.Theme.createActionBar | ||||
| 
 | ||||
| const val WORLD = "Continents" | ||||
| const val COUNTRY = "Countries" | ||||
| const val REGION = "Regions" | ||||
| private val MODE_LIST = listOf(WORLD, COUNTRY, REGION) | ||||
| private val MODE_LIST = listOf(LocType.WORLD, LocType.COUNTRY, LocType.STATE) | ||||
| 
 | ||||
| class StatActivity : AppCompatActivity() { | ||||
| class StatsActivity : AppCompatActivity() { | ||||
|     private lateinit var _binding: ActivityStatBinding | ||||
|     private var activeMode: String = WORLD | ||||
|     private var activeMode = LocType.WORLD | ||||
| 
 | ||||
|     override fun onCreate(savedInstanceState: Bundle?) { | ||||
|         super.onCreate(savedInstanceState) | ||||
| @@ -41,7 +38,7 @@ class StatActivity : AppCompatActivity() { | ||||
|             override fun createFragment(position: Int): Fragment = Fragment() | ||||
|         } | ||||
|         TabLayoutMediator(_binding.tab, _binding.pager) { tab, position -> | ||||
|             tab.text = MODE_LIST[position] | ||||
|             tab.text = MODE_LIST[position].txt | ||||
|         }.attach() | ||||
| 
 | ||||
|         _binding.pager.registerOnPageChangeCallback(object : ViewPager2.OnPageChangeCallback() { | ||||
| @@ -50,12 +47,10 @@ class StatActivity : AppCompatActivity() { | ||||
|                 adapter.refreshMode(activeMode) | ||||
|             } | ||||
|         }) | ||||
|         //adapter.refreshMode(activeMode) | ||||
|     } | ||||
| 
 | ||||
|     override fun onOptionsItemSelected(item: MenuItem): Boolean { | ||||
|         finish() | ||||
|         return super.onOptionsItemSelected(item) | ||||
|     } | ||||
| 
 | ||||
| } | ||||
| @@ -9,7 +9,6 @@ import android.view.ViewGroup | ||||
| import androidx.fragment.app.FragmentActivity | ||||
| import androidx.recyclerview.widget.RecyclerView | ||||
| import com.google.android.material.checkbox.MaterialCheckBox | ||||
| import net.helcel.beans.R | ||||
| import net.helcel.beans.activity.fragment.EditPlaceColorFragment | ||||
| import net.helcel.beans.activity.fragment.EditPlaceFragment | ||||
| import net.helcel.beans.countries.GeoLoc | ||||
| @@ -79,7 +78,7 @@ class GeolocListAdapter( | ||||
|             _binding.textView.backgroundTintList = | ||||
|                 ColorStateList.valueOf(colorWrapper(ctx, android.R.attr.colorBackground).color) | ||||
|  | ||||
|             if (el.shouldShowChildren(ctx)) | ||||
|             if (el.children.isNotEmpty()) | ||||
|                 bindGroup(el) | ||||
|  | ||||
|             refreshCheck(el) | ||||
| @@ -94,7 +93,7 @@ class GeolocListAdapter( | ||||
|         } | ||||
|  | ||||
|         fun addListeners(el: GeoLoc, expandLambda: () -> Boolean) { | ||||
|             if (el.shouldShowChildren(ctx)) { | ||||
|             if (el.children.isNotEmpty()) { | ||||
|                 _binding.textView.setOnClickListener { expandLambda() } | ||||
|             } | ||||
|             _binding.checkBox.setOnClickListener { | ||||
| @@ -141,23 +140,13 @@ class GeolocListAdapter( | ||||
|  | ||||
|         private fun refreshCheck(geoLoc: GeoLoc) { | ||||
|             _binding.checkBox.checkedState = | ||||
|                 if (Data.visits.getVisited(geoLoc) == AUTO_GROUP && !Settings.isRegional(ctx) && geoLoc.type == GeoLoc.LocType.COUNTRY) { | ||||
|                 if (Data.visits.getVisited(geoLoc) !in listOf(NO_GROUP, AUTO_GROUP)) { | ||||
|                     MaterialCheckBox.STATE_CHECKED | ||||
|                 } else if (Data.visits.getVisited(geoLoc) !in listOf(NO_GROUP, AUTO_GROUP)) { | ||||
|                     MaterialCheckBox.STATE_CHECKED | ||||
|                 } else if ( | ||||
|                            Data.visits.getVisited(geoLoc) == AUTO_GROUP | ||||
|                         && Settings.isRegional(ctx) | ||||
|                         && geoLoc.type == GeoLoc.LocType.COUNTRY | ||||
|                         && (geoLoc.children.all { Data.visits.getVisited(it) == NO_GROUP }) | ||||
|                         && geoLoc != Data.clearing_geoloc | ||||
|                     ) { | ||||
|                     MaterialCheckBox.STATE_CHECKED | ||||
|                 } else if (geoLoc.children.isNotEmpty() && geoLoc.children.all { | ||||
|                         Data.visits.getVisited( | ||||
|                             it | ||||
|                         ) != NO_GROUP | ||||
|                     }) { | ||||
|                 } else if (geoLoc.children.isNotEmpty() && | ||||
|                     geoLoc.children.all { | ||||
|                         Data.visits.getVisited(it) !in listOf(NO_GROUP, AUTO_GROUP) | ||||
|                     } | ||||
|                 ) { | ||||
|                     Data.visits.setVisited(geoLoc, AUTO_GROUP) | ||||
|                     MaterialCheckBox.STATE_CHECKED | ||||
|                 } else if (geoLoc.children.any { Data.visits.getVisited(it) != NO_GROUP }) { | ||||
| @@ -165,7 +154,7 @@ class GeolocListAdapter( | ||||
|                     MaterialCheckBox.STATE_INDETERMINATE | ||||
|                 } else { | ||||
|                     Data.visits.setVisited(geoLoc, NO_GROUP) | ||||
|                     if (geoLoc == Data.clearing_geoloc) { | ||||
|                     if (Data.clearing_geoloc == geoLoc) { | ||||
|                         Data.clearing_geoloc = null | ||||
|                     } | ||||
|                     MaterialCheckBox.STATE_UNCHECKED | ||||
|   | ||||
| @@ -1,16 +1,13 @@ | ||||
| package net.helcel.beans.activity.adapter | ||||
|  | ||||
| import android.annotation.SuppressLint | ||||
| import android.content.Context | ||||
| import android.view.LayoutInflater | ||||
| import android.view.ViewGroup | ||||
| import androidx.recyclerview.widget.RecyclerView | ||||
| import com.google.android.material.textview.MaterialTextView | ||||
| import net.helcel.beans.R | ||||
| import net.helcel.beans.activity.COUNTRY | ||||
| import net.helcel.beans.activity.REGION | ||||
| import net.helcel.beans.activity.WORLD | ||||
| import net.helcel.beans.countries.GeoLoc | ||||
| import net.helcel.beans.countries.GeoLoc.LocType | ||||
| import net.helcel.beans.countries.World | ||||
| import net.helcel.beans.databinding.ItemListGroupBinding | ||||
| import net.helcel.beans.helper.AUTO_GROUP | ||||
| @@ -21,14 +18,15 @@ import net.helcel.beans.helper.Theme.getContrastColor | ||||
|  | ||||
| class StatsListAdapter(private val stats: RecyclerView, private val total: MaterialTextView) : | ||||
|     RecyclerView.Adapter<StatsListAdapter.StatsViewHolder>() { | ||||
|     private var locMode: String = WORLD | ||||
|     private var locMode = LocType.WORLD | ||||
|     private lateinit var ctx: Context | ||||
|     private var countMode: Boolean = true | ||||
|     private var initialSum: Int = 0 | ||||
|  | ||||
|     private val wwwTotal: List<GeoLoc> = World.WWW.children.toList() | ||||
|     private val countryTotal: List<GeoLoc> = World.WWW.children.flatMap { it.children } | ||||
|     private val stateTotal: List<GeoLoc> = World.WWW.children.flatMap{ it.children.flatMap { itt -> itt.children } } | ||||
|     private val stateTotal: List<GeoLoc> = | ||||
|         World.WWW.children.flatMap { it.children.flatMap { itt -> itt.children } } | ||||
|  | ||||
|     override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): StatsViewHolder { | ||||
|         ctx = parent.context | ||||
| @@ -40,7 +38,12 @@ class StatsListAdapter(private val stats: RecyclerView, private val total: Mater | ||||
|  | ||||
|     override fun onBindViewHolder(holder: StatsViewHolder, pos: Int) { | ||||
|         initialSum += if (pos == itemCount - 1) { | ||||
|             holder.bind(Pair(AUTO_GROUP, Groups.Group(AUTO_GROUP, ctx.getString(R.string.uncategorized)))) | ||||
|             holder.bind( | ||||
|                 Pair( | ||||
|                     AUTO_GROUP, | ||||
|                     Groups.Group(AUTO_GROUP, ctx.getString(R.string.uncategorized)) | ||||
|                 ) | ||||
|             ) | ||||
|         } else { | ||||
|             holder.bind(Data.groups.getGroupFromPos(pos)) | ||||
|         } | ||||
| @@ -54,22 +57,22 @@ class StatsListAdapter(private val stats: RecyclerView, private val total: Mater | ||||
|     private fun getTotal(): Int { | ||||
|         return if (countMode) { | ||||
|             when (locMode) { | ||||
|                 WORLD -> wwwTotal.size | ||||
|                 COUNTRY -> countryTotal.size | ||||
|                 REGION -> stateTotal.size | ||||
|                 LocType.WORLD -> wwwTotal.size | ||||
|                 LocType.COUNTRY -> countryTotal.size | ||||
|                 LocType.STATE -> stateTotal.size | ||||
|                 else -> 0 | ||||
|             } | ||||
|         } else { | ||||
|             when (locMode) { | ||||
|                 WORLD -> wwwTotal.sumOf { it.area } | ||||
|                 COUNTRY -> countryTotal.sumOf { it.area } | ||||
|                 REGION -> stateTotal.sumOf { it.area } | ||||
|                 LocType.WORLD -> wwwTotal.sumOf { it.area } | ||||
|                 LocType.COUNTRY -> countryTotal.sumOf { it.area } | ||||
|                 LocType.STATE -> stateTotal.sumOf { it.area } | ||||
|                 else -> 0 | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     fun refreshMode(mode: String) { | ||||
|     fun refreshMode(mode: LocType) { | ||||
|         val sum = (0 until itemCount).map { | ||||
|             val viewHolder = stats.findViewHolderForAdapterPosition(it) as? StatsViewHolder | ||||
|             viewHolder?.refresh(mode) | ||||
| @@ -116,22 +119,22 @@ class StatsListAdapter(private val stats: RecyclerView, private val total: Mater | ||||
|                     .flatten().flatten() | ||||
|         } | ||||
|  | ||||
|         fun refresh(mode: String): Int { | ||||
|         fun refresh(mode: LocType): Int { | ||||
|             locMode = mode | ||||
|             return if (countMode) { | ||||
|                 val count = when (locMode) { | ||||
|                     WORLD -> wwwCount.size | ||||
|                     COUNTRY -> countryCount.size | ||||
|                     REGION -> stateCount.size | ||||
|                     LocType.WORLD -> wwwCount.size | ||||
|                     LocType.COUNTRY -> countryCount.size | ||||
|                     LocType.STATE -> stateCount.size | ||||
|                     else -> -1 | ||||
|                 } | ||||
|                 _binding.name.text = count.toString() | ||||
|                 count | ||||
|             } else { | ||||
|                 val area = when (locMode) { | ||||
|                     WORLD -> wwwCount.sumOf { it.area } | ||||
|                     COUNTRY -> countryCount.sumOf { it.area } | ||||
|                     REGION -> stateCount.sumOf { it.area } | ||||
|                     LocType.WORLD -> wwwCount.sumOf { it.area } | ||||
|                     LocType.COUNTRY -> countryCount.sumOf { it.area } | ||||
|                     LocType.STATE -> stateCount.sumOf { it.area } | ||||
|                     else -> -1 | ||||
|                 } | ||||
|                 _binding.name.text = area.toString() | ||||
|   | ||||
| @@ -8,7 +8,6 @@ import androidx.preference.PreferenceFragmentCompat | ||||
| import androidx.preference.PreferenceManager | ||||
| import com.google.android.material.dialog.MaterialAlertDialogBuilder | ||||
| import net.helcel.beans.R | ||||
| import net.helcel.beans.activity.MainActivity | ||||
| import net.helcel.beans.countries.GeoLocImporter | ||||
| import net.helcel.beans.helper.Data | ||||
| import net.helcel.beans.helper.DialogCloser | ||||
| @@ -58,18 +57,22 @@ class SettingsFragment : PreferenceFragmentCompat(), DialogCloser { | ||||
|                         .setMessage(R.string.delete_regions) | ||||
|                         .setPositiveButton(android.R.string.ok) { _, _ -> | ||||
|                             GeoLocImporter.clearStates() | ||||
|                             val sp = PreferenceManager.getDefaultSharedPreferences(ctx) | ||||
|                             sp.edit().putString(ctx.getString(R.string.key_regional), ctx.getString(R.string.off)).apply() | ||||
|                             PreferenceManager.getDefaultSharedPreferences(ctx).edit().putString( | ||||
|                                 ctx.getString(R.string.key_regional), | ||||
|                                 ctx.getString(R.string.off) | ||||
|                             ).apply() | ||||
|                             refreshPreferences() | ||||
|                         } | ||||
|                         .setNegativeButton(android.R.string.cancel) { _, _ -> } | ||||
|                         .show() | ||||
|                     false | ||||
|                 } | ||||
|  | ||||
|                 ctx.getString(R.string.on) -> { | ||||
|                     GeoLocImporter.importStates(ctx, true) | ||||
|                     true | ||||
|                 } | ||||
|  | ||||
|                 else -> false | ||||
|             } | ||||
|         } | ||||
| @@ -111,7 +114,7 @@ class SettingsFragment : PreferenceFragmentCompat(), DialogCloser { | ||||
|         // When turning groups off, select one group to keep and reassign everything | ||||
|         Data.selected_group?.let { selectedGroup -> | ||||
|             // Reassign all visited that are not to selectedGroup to selectedGroup | ||||
|             Data.visits.reassignAllVisitedtoGroup(selectedGroup.key) | ||||
|             Data.visits.reassignAllVisitedToGroup(selectedGroup.key) | ||||
|  | ||||
|             // Delete all groups that are not selectedGroup | ||||
|             Data.groups.deleteAllExcept(selectedGroup.key) | ||||
| @@ -124,7 +127,8 @@ class SettingsFragment : PreferenceFragmentCompat(), DialogCloser { | ||||
|             // Actually change preference | ||||
|             val ctx = requireContext() | ||||
|             val sp = PreferenceManager.getDefaultSharedPreferences(ctx) | ||||
|             sp.edit().putString(ctx.getString(R.string.key_group), ctx.getString(R.string.off)).apply() | ||||
|             sp.edit().putString(ctx.getString(R.string.key_group), ctx.getString(R.string.off)) | ||||
|                 .apply() | ||||
|  | ||||
|             // Refresh entire preference fragment to reflect changes | ||||
|             refreshPreferences() | ||||
|   | ||||
| @@ -1,13 +1,10 @@ | ||||
| package net.helcel.beans.countries | ||||
|  | ||||
| import android.content.Context | ||||
| import net.helcel.beans.helper.Settings | ||||
|  | ||||
|  | ||||
| interface GeoLoc { | ||||
|  | ||||
|     enum class LocType { | ||||
|         WORLD, GROUP, CUSTOM_GROUP, COUNTRY, STATE; | ||||
|     enum class LocType(val txt: String) { | ||||
|         WORLD("World"), GROUP("Group"), CUSTOM_GROUP("Group"), COUNTRY("Country"), STATE("State"); | ||||
|     } | ||||
|  | ||||
|     val code: String | ||||
| @@ -16,15 +13,6 @@ interface GeoLoc { | ||||
|  | ||||
|     val type: LocType | ||||
|     val children: Set<GeoLoc> | ||||
|  | ||||
|     fun shouldShowChildren(ctx: Context): Boolean { | ||||
|         if (children.isEmpty()) | ||||
|             return false | ||||
|         if (type == LocType.COUNTRY && !Settings.isRegional(ctx)) | ||||
|             return false | ||||
|         return true | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -25,17 +25,14 @@ object GeoLocImporter { | ||||
|     fun clearStates() { | ||||
|         Country.entries.forEach { country -> | ||||
|             if (country.children.any { region -> | ||||
|                 Data.visits.getVisited(region) != NO_GROUP | ||||
|             }) { | ||||
|                     Data.visits.getVisited(region) != NO_GROUP | ||||
|                 }) { | ||||
|                 if (Data.visits.getVisited(country) == NO_GROUP) { | ||||
|                     Data.visits.setVisited(country, AUTO_GROUP) | ||||
|                 } | ||||
|                 country.children.forEach { region -> | ||||
|                     Data.visits.setVisited(region, NO_GROUP) | ||||
|                 } | ||||
|                 Data.saveData() | ||||
|             } | ||||
|             country.children.clear() | ||||
|         } | ||||
|         Data.saveData() | ||||
|     } | ||||
| } | ||||
| @@ -13,10 +13,7 @@ enum class World(override val fullName: String, override val children: Set<GeoLo | ||||
|     override val area = children.fold(0) { acc, i -> | ||||
|         acc + i.area | ||||
|     } | ||||
|  | ||||
|  | ||||
|      | ||||
|     override val type = GeoLoc.LocType.WORLD | ||||
|     override val code = this.name | ||||
|  | ||||
|  | ||||
| } | ||||
| @@ -46,7 +46,7 @@ class Visits(val id: Int, private val locs: HashMap<String, Int>) { | ||||
|         return locs.filter { it.value == key }.keys.toList() | ||||
|     } | ||||
|  | ||||
|     fun reassignAllVisitedtoGroup(group: Int) { | ||||
|     fun reassignAllVisitedToGroup(group: Int) { | ||||
|         val keys = locs.filter { (_, grp) -> | ||||
|             grp !in listOf(NO_GROUP, AUTO_GROUP) | ||||
|         }.keys | ||||
|   | ||||
| @@ -1,12 +1,8 @@ | ||||
| package net.helcel.beans.svg | ||||
|  | ||||
| import android.content.Context | ||||
| import net.helcel.beans.countries.Country | ||||
| import net.helcel.beans.countries.GeoLoc | ||||
| import net.helcel.beans.countries.State | ||||
| import net.helcel.beans.countries.World | ||||
| import net.helcel.beans.helper.AUTO_GROUP | ||||
| import net.helcel.beans.helper.Data | ||||
| import net.helcel.beans.helper.Data.groups | ||||
| import net.helcel.beans.helper.Data.visits | ||||
| import net.helcel.beans.helper.NO_GROUP | ||||
| @@ -43,29 +39,16 @@ class CSSWrapper(private val ctx: Context) { | ||||
|     private fun refresh() { | ||||
|         val id = if (Settings.isRegional(ctx)) "1" else "2" | ||||
|         customCSS = visits.getVisitedByValue().map { (k, v) -> | ||||
|             if (!Settings.isRegional(ctx) && k == AUTO_GROUP) { | ||||
|             if (groups.getGroupFromKey(k).key != NO_GROUP || (!Settings.isRegional(ctx) && k == AUTO_GROUP)) { | ||||
|                 v.joinToString(",") { "#${it}$id,#${it}" } + "{fill:${ | ||||
|                     colorToHex6(colorWrapper(ctx, android.R.attr.colorPrimary)) | ||||
|                     colorToHex6( | ||||
|                         if (k == AUTO_GROUP) | ||||
|                             colorWrapper(ctx, android.R.attr.colorPrimary) | ||||
|                         else groups.getGroupFromKey(k).color | ||||
|                     ) | ||||
|                 };}" | ||||
|             } | ||||
|             else if (Settings.isRegional(ctx) && k == AUTO_GROUP) { | ||||
|                 Country.entries.filter { it.code in v } | ||||
|                     .filter { | ||||
|                         it.children.all { itt -> | ||||
|                             visits.getVisited(itt) == NO_GROUP | ||||
|                         } | ||||
|                     }.map { | ||||
|                         it.code | ||||
|                     }.takeIf { it.isNotEmpty() }?.joinToString(",") { "#${it}$id,#${it}" } + "{fill:${ | ||||
|                     colorToHex6(colorWrapper(ctx, android.R.attr.colorPrimary)) | ||||
|                 };}" | ||||
|             } | ||||
|             else if (groups.getGroupFromKey(k).key == NO_GROUP) | ||||
|             } else { | ||||
|                 "" | ||||
|             else { | ||||
|                 v.joinToString(",") { "#${it}$id,#${it}" } + "{fill:${ | ||||
|                     colorToHex6(groups.getGroupFromKey(k).color) | ||||
|                 };}" | ||||
|             } | ||||
|         }.joinToString("") | ||||
|     } | ||||
|   | ||||
| @@ -8,13 +8,14 @@ import net.helcel.beans.R | ||||
| class SVGWrapper(ctx: Context) { | ||||
|  | ||||
|     val sharedPreferences = PreferenceManager.getDefaultSharedPreferences(ctx) | ||||
|     val svgFile = when (sharedPreferences.getString(ctx.getString(R.string.key_projection), ctx.getString(R.string.mercator))) { | ||||
|     private val svgFile = when (sharedPreferences.getString( | ||||
|         ctx.getString(R.string.key_projection), | ||||
|         ctx.getString(R.string.mercator) | ||||
|     )) { | ||||
|         ctx.getString(R.string.azimuthalequidistant) -> "aeqd01.svg" | ||||
|         ctx.getString(R.string.equirectangular) -> "eqdc01.svg" | ||||
|         ctx.getString(R.string.equidistant) -> "eqearth01.svg" | ||||
|         ctx.getString(R.string.mercator) -> "mercator01.svg" | ||||
|         ctx.getString(R.string.loximuthal) -> "loxim01.svg" | ||||
|         ctx.getString(R.string.webmercator) -> "webmercator01.svg" | ||||
|         ctx.getString(R.string.mercator) -> "webmercator01.svg" | ||||
|         else -> "webmercator01.svg" | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -12,12 +12,11 @@ | ||||
|         android:orientation="vertical"> | ||||
|  | ||||
|         <com.google.android.material.imageview.ShapeableImageView | ||||
|             android:layout_width="250dp" | ||||
|             android:layout_height="250dp" | ||||
|             android:layout_marginTop="40dp" | ||||
|             android:layout_marginBottom="30dp" | ||||
|             android:layout_width="300dp" | ||||
|             android:layout_height="300dp" | ||||
|             android:layout_marginTop="20dp" | ||||
|             android:contentDescription="@string/logo" | ||||
|             android:src="@mipmap/ic_launcher_round" /> | ||||
|             android:src="@drawable/ic_launcher_foreground" /> | ||||
|  | ||||
|         <com.google.android.material.textview.MaterialTextView | ||||
|             android:layout_width="match_parent" | ||||
|   | ||||
| @@ -19,8 +19,6 @@ | ||||
|     <string-array name="map_projection"> | ||||
|         <item>@string/azimuthalequidistant</item> | ||||
|         <item>@string/equirectangular</item> | ||||
|         <item>@string/equidistant</item> | ||||
|         <item>@string/mercator</item> | ||||
|         <item>@string/loximuthal</item> | ||||
|         <item>@string/webmercator</item> | ||||
|  | ||||
|   | ||||
							
								
								
									
										10
									
								
								gensvg.sh
									
									
									
									
									
								
							
							
						
						| @@ -132,12 +132,10 @@ toSVG_01() { | ||||
|     done | ||||
|  | ||||
|  | ||||
|     # "$mapshaper" -i combine-files ${input_files[@]} -proj eqdc +lat_1=55 +lat_2=60 -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/eqdc01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     # "$mapshaper" -i combine-files ${input_files[@]} -proj loxim -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/loxim01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     # "$mapshaper" -i combine-files ${input_files[@]} -proj eqearth -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/eqearth01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     "$mapshaper" -i combine-files ${input_files[@]} -proj merc +lat_ts=47.36667 -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/mercator01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     # "$mapshaper" -i combine-files ${input_files[@]} -proj webmercator -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/webmercator01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     # "$mapshaper" -i combine-files ${input_files[@]} -proj aeqd +lat_0=90 -simplify 0.005 weighted keep-shapes resolution=1200x1200 -o ./app/src/main/assets/aeqd01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     "$mapshaper" -i combine-files ${input_files[@]} snap -proj eqdc +lat_1=55 +lat_2=60 -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/eqdc01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     "$mapshaper" -i combine-files ${input_files[@]} snap -proj loxim densify -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/loxim01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     "$mapshaper" -i combine-files ${input_files[@]} snap -proj webmercator densify -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/webmercator01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     "$mapshaper" -i combine-files ${input_files[@]} snap -proj aeqd +lat_0=90 densify -simplify 0.005 weighted keep-shapes resolution=1200x1200 -o ./app/src/main/assets/aeqd01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
| } | ||||
|  | ||||
| do_1() { | ||||
|   | ||||