From 6015d8471784aabdefe297832c93d8337f0e9b87 Mon Sep 17 00:00:00 2001
From: amar <>
Date: Wed, 31 Mar 2021 10:55:36 +0530
Subject: [PATCH] minor ui changes
---
.../ui/detail/WeatherDetailActivity.java | 26 ++----
.../com/olrep/theweatherapp/utils/Utils.java | 4 +
.../res/layout/weather_detail_activity.xml | 82 +++++++------------
app/src/main/res/values/dimen.xml | 4 +
app/src/main/res/values/strings.xml | 5 ++
5 files changed, 51 insertions(+), 70 deletions(-)
create mode 100644 app/src/main/res/values/dimen.xml
diff --git a/app/src/main/java/com/olrep/theweatherapp/ui/detail/WeatherDetailActivity.java b/app/src/main/java/com/olrep/theweatherapp/ui/detail/WeatherDetailActivity.java
index b43bc01..157d2c4 100644
--- a/app/src/main/java/com/olrep/theweatherapp/ui/detail/WeatherDetailActivity.java
+++ b/app/src/main/java/com/olrep/theweatherapp/ui/detail/WeatherDetailActivity.java
@@ -86,12 +86,11 @@ protected void onCreate(@Nullable Bundle savedInstanceState) {
// various ui elements to be shown
final TextView cityTv = findViewById(R.id.tv_city_name);
final TextView lastUpdatedTv = findViewById(R.id.tv_last_updated);
- final TextView tempMinTv = findViewById(R.id.tv_min_temp);
- final TextView tempMaxTv = findViewById(R.id.tv_max_temp);
- final TextView tempTv = findViewById(R.id.tv_temp_large);
+ final TextView largeTempTv = findViewById(R.id.tv_temp_large);
+ final TextView tempRangeTv = findViewById(R.id.tv_temp_range);
final TextView tempFeelsTv = findViewById(R.id.tv_temp_desc);
final TextView weatherDescTv = findViewById(R.id.tv_weather_desc);
- final ImageView weatherConditionTv = findViewById(R.id.iv_weather_condition_2x);
+ final ImageView weatherConditionIv = findViewById(R.id.iv_weather_condition_2x);
// observing current weather live data via view model
// both cached (from db) and network call gets updated and propagated here
@@ -103,21 +102,15 @@ protected void onCreate(@Nullable Bundle savedInstanceState) {
if (resultPair != null && resultPair.first && resultPair.second != null) {
Log.d(TAG, "setting views");
- StringBuilder stringBuilder = new StringBuilder();
- Picasso.get().load(Utils.getIconUrl(resultPair.second.weather_icon)).into(weatherConditionTv);
+ Picasso.get().load(Utils.getIconUrl2x(resultPair.second.weather_icon)).into(weatherConditionIv);
- cityTv.setText(stringBuilder.append(resultPair.second.city).append(", ").append(resultPair.second.country).toString());
+ cityTv.setText(cityTv.getContext().getString(R.string.city_country, resultPair.second.city, resultPair.second.country));
lastUpdatedTv.setText(Utils.lastUpdated(resultPair.second.last_updated));
- tempMinTv.setText(String.valueOf(resultPair.second.temp_min));
- tempMaxTv.setText(String.valueOf(resultPair.second.temp_max));
-
- stringBuilder.setLength(0);
- tempTv.setText(stringBuilder.append((resultPair.second.temp)).append("°").toString());
-
- stringBuilder.setLength(0);
- tempFeelsTv.setText(stringBuilder.append("Temperate at this time feels like ").append(resultPair.second.temp_feels_like).append("°").toString());
- weatherDescTv.setText(resultPair.second.weather_description);
+ largeTempTv.setText(largeTempTv.getContext().getString(R.string.large_temp, String.valueOf(resultPair.second.temp)));
+ tempRangeTv.setText(tempRangeTv.getContext().getString(R.string.temp_range, String.valueOf(resultPair.second.temp_min), String.valueOf(resultPair.second.temp_max)));
+ tempFeelsTv.setText(tempFeelsTv.getContext().getString(R.string.temp_feels_like, String.valueOf(resultPair.second.temp_feels_like)));
+ weatherDescTv.setText(weatherDescTv.getContext().getString(R.string.weather_condition, resultPair.second.weather_description));
favButton.setVisibility(View.VISIBLE);
@@ -137,7 +130,6 @@ protected void onCreate(@Nullable Bundle savedInstanceState) {
// to toggle add/remove icon of floating button
private int getFavRes(boolean favourite) {
return favourite ? R.drawable.ic_close : R.drawable.ic_add;
-
}
// checking whether it's a fav already
diff --git a/app/src/main/java/com/olrep/theweatherapp/utils/Utils.java b/app/src/main/java/com/olrep/theweatherapp/utils/Utils.java
index ee8d7ec..741193b 100644
--- a/app/src/main/java/com/olrep/theweatherapp/utils/Utils.java
+++ b/app/src/main/java/com/olrep/theweatherapp/utils/Utils.java
@@ -8,6 +8,10 @@ public static String getIconUrl(String iconId) {
return "http://openweathermap.org/img/wn/" + iconId + ".png"; // can add @Nx before . to get bigger size todo
}
+ public static String getIconUrl2x(String iconId) {
+ return "http://openweathermap.org/img/wn/" + iconId + "@2x.png"; // can add @Nx before . to get bigger size todo
+ }
+
// returns the last updated time diff as "4 hours ago"
public static String lastUpdated(long lastUpdated) {
return (DateUtils.getRelativeTimeSpanString(lastUpdated)).toString();
diff --git a/app/src/main/res/layout/weather_detail_activity.xml b/app/src/main/res/layout/weather_detail_activity.xml
index 1cec20b..7e04ded 100644
--- a/app/src/main/res/layout/weather_detail_activity.xml
+++ b/app/src/main/res/layout/weather_detail_activity.xml
@@ -9,7 +9,9 @@
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
- android:textSize="35sp"
+ android:fontFamily="sans-serif-smallcaps"
+ android:textColor="@color/purple_500"
+ android:textSize="25sp"
tools:text="Bangalore, IN" />
@@ -30,6 +34,7 @@
android:id="@+id/tv_last_updated"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
+ android:textSize="20sp"
tools:text="3d4h" />
@@ -53,74 +58,45 @@
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:layout_marginStart="20dp"
- android:textSize="50sp"
+ android:textSize="40sp"
tools:text="34°" />
-
-
-
-
-
-
-
-
-
-
-
-
-
+ android:layout_marginStart="10dp"
+ android:fontFamily="sans-serif"
+ android:text="Temperature today will be between 35° and 45°."
+ android:textColor="@android:color/black"
+ android:textSize="@dimen/font_small" />
+ android:layout_below="@id/tv_temp_range"
+ android:layout_marginStart="10dp"
+ android:layout_marginTop="10dp"
+ android:fontFamily="sans-serif"
+ android:textColor="@android:color/black"
+ android:textSize="@dimen/font_small"
+ tools:text="But temperature right now feels like 45°." />
+ android:fontFamily="sans-serif"
+ android:textColor="@android:color/black"
+ android:textSize="@dimen/font_small"
+ tools:text="Today's weather condition is: mist." />
\ No newline at end of file
diff --git a/app/src/main/res/values/dimen.xml b/app/src/main/res/values/dimen.xml
new file mode 100644
index 0000000..cb218a8
--- /dev/null
+++ b/app/src/main/res/values/dimen.xml
@@ -0,0 +1,4 @@
+
+
+ 17sp
+
\ No newline at end of file
diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml
index b6a37b0..ee90932 100644
--- a/app/src/main/res/values/strings.xml
+++ b/app/src/main/res/values/strings.xml
@@ -1,4 +1,9 @@
TheWeatherApp
Enter city name
+ %1$s, %2$s
+ %1$s°
+ Temperature today will be between %1$s° and %2$2s°.
+ But temperature right now feels like %1$s°.
+ Today\'s weather condition is: %1$s.
\ No newline at end of file