add settings
add permissions to access ssid, fix error in theme, add settings activity with shared preferences and support German and English
This commit is contained in:
@@ -6,8 +6,8 @@ android {
|
|||||||
applicationId "de.weseng.wifiweatherstation"
|
applicationId "de.weseng.wifiweatherstation"
|
||||||
minSdkVersion 15
|
minSdkVersion 15
|
||||||
targetSdkVersion 28
|
targetSdkVersion 28
|
||||||
versionCode 1
|
versionCode 20190302
|
||||||
versionName "1.0"
|
versionName "2019.3.2"
|
||||||
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
|
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
|
||||||
}
|
}
|
||||||
buildTypes {
|
buildTypes {
|
||||||
@@ -25,4 +25,5 @@ dependencies {
|
|||||||
testImplementation 'junit:junit:4.12'
|
testImplementation 'junit:junit:4.12'
|
||||||
androidTestImplementation 'com.android.support.test:runner:1.0.2'
|
androidTestImplementation 'com.android.support.test:runner:1.0.2'
|
||||||
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
|
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
|
||||||
|
implementation 'com.android.support:design:28.0.0'
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,22 +3,31 @@
|
|||||||
package="de.weseng.wifiweatherstation">
|
package="de.weseng.wifiweatherstation">
|
||||||
|
|
||||||
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
|
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
|
||||||
|
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
|
||||||
|
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <!-- or ACCESS_FINE_LOCATION for SSID -->
|
||||||
<uses-permission android:name="android.permission.INTERNET" />
|
<uses-permission android:name="android.permission.INTERNET" />
|
||||||
|
|
||||||
<application
|
<application
|
||||||
android:usesCleartextTraffic="true"
|
|
||||||
android:allowBackup="true"
|
android:allowBackup="true"
|
||||||
android:icon="@mipmap/ic_launcher"
|
android:icon="@mipmap/ic_launcher"
|
||||||
android:label="@string/app_name"
|
android:label="@string/app_name"
|
||||||
android:roundIcon="@mipmap/ic_launcher_round"
|
android:roundIcon="@mipmap/ic_launcher_round"
|
||||||
android:supportsRtl="true"
|
android:supportsRtl="true"
|
||||||
android:theme="@style/AppTheme">
|
android:theme="@style/DarkTheme"
|
||||||
|
android:usesCleartextTraffic="true">
|
||||||
<activity android:name=".MainActivity">
|
<activity android:name=".MainActivity">
|
||||||
<intent-filter>
|
<intent-filter>
|
||||||
<action android:name="android.intent.action.MAIN" />
|
<action android:name="android.intent.action.MAIN" />
|
||||||
|
|
||||||
<category android:name="android.intent.category.LAUNCHER" />
|
<category android:name="android.intent.category.LAUNCHER" />
|
||||||
</intent-filter>
|
</intent-filter>
|
||||||
</activity>
|
</activity>
|
||||||
|
<activity android:name=".SettingsActivity"
|
||||||
|
android:parentActivityName=".MainActivity">
|
||||||
|
<!-- The meta-data tag is required if you support API level 15 and lower -->
|
||||||
|
<meta-data
|
||||||
|
android:name="android.support.PARENT_ACTIVITY"
|
||||||
|
android:value=".MainActivity" />
|
||||||
|
</activity>
|
||||||
</application>
|
</application>
|
||||||
|
|
||||||
</manifest>
|
</manifest>
|
||||||
@@ -2,13 +2,18 @@ package de.weseng.wifiweatherstation;
|
|||||||
|
|
||||||
import android.app.ProgressDialog;
|
import android.app.ProgressDialog;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.SharedPreferences;
|
||||||
import android.graphics.Bitmap;
|
import android.graphics.Bitmap;
|
||||||
import android.graphics.Color;
|
import android.graphics.Color;
|
||||||
import android.net.ConnectivityManager;
|
import android.net.ConnectivityManager;
|
||||||
import android.net.NetworkInfo;
|
import android.net.NetworkInfo;
|
||||||
|
import android.net.wifi.SupplicantState;
|
||||||
|
import android.net.wifi.WifiConfiguration;
|
||||||
|
import android.net.wifi.WifiInfo;
|
||||||
|
import android.net.wifi.WifiManager;
|
||||||
import android.support.v7.app.AppCompatActivity;
|
import android.support.v7.app.AppCompatActivity;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.util.Log;
|
|
||||||
import android.view.KeyEvent;
|
import android.view.KeyEvent;
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
import android.view.MenuItem;
|
import android.view.MenuItem;
|
||||||
@@ -17,15 +22,20 @@ import android.webkit.WebView;
|
|||||||
import android.webkit.WebViewClient;
|
import android.webkit.WebViewClient;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
|
||||||
public class MainActivity extends AppCompatActivity {
|
public class MainActivity extends AppCompatActivity {
|
||||||
|
public static final String PREFS_NAME = "Settings";
|
||||||
WebView myWebView;
|
WebView myWebView;
|
||||||
|
public static String MESSAGE = "de.weseng.wifiweatherstation.MESSAGE";
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
final ProgressDialog pd = ProgressDialog.show(MainActivity.this, "",
|
final ProgressDialog pd = ProgressDialog.show(MainActivity.this, "",
|
||||||
"Bitte warten, die Ansicht wird geladen...", true);
|
getString(R.string.loading), true);
|
||||||
|
|
||||||
/* apply layout to the current screen */
|
/* apply layout to the current screen */
|
||||||
setContentView(R.layout.activity_main);
|
setContentView(R.layout.activity_main);
|
||||||
@@ -48,6 +58,11 @@ public class MainActivity extends AppCompatActivity {
|
|||||||
myWebView.setBackgroundColor(Color.TRANSPARENT);
|
myWebView.setBackgroundColor(Color.TRANSPARENT);
|
||||||
myWebView.setPadding(0, 0, 0, 0);
|
myWebView.setPadding(0, 0, 0, 0);
|
||||||
|
|
||||||
|
SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0);
|
||||||
|
String ssidLocal = "\"" + settings.getString("ssidLocal", getString(R.string.ssid)) + "\"";
|
||||||
|
|
||||||
|
MESSAGE = "";
|
||||||
|
|
||||||
myWebView.setWebViewClient(new WebViewClient() {
|
myWebView.setWebViewClient(new WebViewClient() {
|
||||||
@Override
|
@Override
|
||||||
public void onPageStarted(WebView view, String url, Bitmap favicon) {
|
public void onPageStarted(WebView view, String url, Bitmap favicon) {
|
||||||
@@ -79,19 +94,43 @@ public class MainActivity extends AppCompatActivity {
|
|||||||
if (savedInstanceState == null) {
|
if (savedInstanceState == null) {
|
||||||
ConnectivityManager connManager = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
|
ConnectivityManager connManager = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||||
NetworkInfo mWifi = connManager.getNetworkInfo(ConnectivityManager.TYPE_WIFI);
|
NetworkInfo mWifi = connManager.getNetworkInfo(ConnectivityManager.TYPE_WIFI);
|
||||||
|
//MESSAGE = MESSAGE.concat("\nmWifi: " + mWifi.toString());
|
||||||
|
//MESSAGE = MESSAGE.concat("\nmWifi.isConnected(): " + mWifi.isConnected()); // is: true
|
||||||
|
//MESSAGE = MESSAGE.concat("\nmWifi.getExtraInfo(): " + mWifi.getExtraInfo()); // is: null
|
||||||
if (mWifi.isConnected()) {
|
if (mWifi.isConnected()) {
|
||||||
// loadUrl needs: AndroidManifest.xml <application android:usesCleartextTraffic="true"
|
WifiManager wifiMgr = (WifiManager) getApplicationContext().getSystemService(Context.WIFI_SERVICE);
|
||||||
if (mWifi.getExtraInfo() != null && mWifi.getExtraInfo().equals("\"FRITZ!Box Fon WLAN 7360\"")) {
|
WifiInfo wifiInfo = wifiMgr.getConnectionInfo();
|
||||||
//Toast.makeText(getApplicationContext(), "intern", Toast.LENGTH_LONG).show();
|
//MESSAGE = MESSAGE.concat("\nwifiInfo: " + wifiInfo.toString());
|
||||||
myWebView.loadUrl("http://192.168.178.5/site/wifi-weather-station/");
|
if (wifiInfo.getSupplicantState() == SupplicantState.COMPLETED) {
|
||||||
} else {
|
WifiManager wifiManager = (WifiManager) getApplicationContext().getSystemService(Context.WIFI_SERVICE);
|
||||||
//Toast.makeText(getApplicationContext(), "extern", Toast.LENGTH_LONG).show();
|
WifiInfo info = wifiManager.getConnectionInfo();
|
||||||
myWebView.loadUrl("http://inetsrv.no-ip.org/site/wifi-weather-station/");
|
String ssid = findSSIDForWifiInfo(wifiManager, info);
|
||||||
|
MESSAGE = MESSAGE.concat("\nSSID: " + ssid);
|
||||||
|
// loadUrl needs: AndroidManifest.xml <application android:usesCleartextTraffic="true"
|
||||||
|
//if (ssidIntern.contains(ssid)) {
|
||||||
|
if (ssid.equals(ssidLocal)) {
|
||||||
|
MESSAGE = MESSAGE.concat("\nconnection: internal");
|
||||||
|
//Toast.makeText(getApplicationContext(), "intern", Toast.LENGTH_LONG).show();
|
||||||
|
myWebView.loadUrl(getString(R.string.url_local));
|
||||||
|
} else {
|
||||||
|
MESSAGE = MESSAGE.concat("\nconnection: external");
|
||||||
|
//Toast.makeText(getApplicationContext(), "extern", Toast.LENGTH_LONG).show();
|
||||||
|
myWebView.loadUrl(getString(R.string.url_global));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
public String findSSIDForWifiInfo(WifiManager wifiManager, WifiInfo wifiInfo) {
|
||||||
|
List<WifiConfiguration> listOfConfigurations = wifiManager.getConfiguredNetworks();
|
||||||
|
for (int index = 0; index < listOfConfigurations.size(); index++) {
|
||||||
|
WifiConfiguration configuration = listOfConfigurations.get(index);
|
||||||
|
if (configuration.networkId == wifiInfo.getNetworkId()) {
|
||||||
|
return configuration.SSID;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
@Override
|
@Override
|
||||||
public boolean onKeyDown(int keyCode, KeyEvent event) {
|
public boolean onKeyDown(int keyCode, KeyEvent event) {
|
||||||
// Check if the key event was the Back button and if there's history
|
// Check if the key event was the Back button and if there's history
|
||||||
@@ -107,23 +146,20 @@ public class MainActivity extends AppCompatActivity {
|
|||||||
@Override
|
@Override
|
||||||
public boolean onCreateOptionsMenu(Menu menu) {
|
public boolean onCreateOptionsMenu(Menu menu) {
|
||||||
// Inflate the menu; this adds items to the action bar if it is present.
|
// Inflate the menu; this adds items to the action bar if it is present.
|
||||||
//getMenuInflater().inflate(R.menu.menu_main, menu);
|
getMenuInflater().inflate(R.menu.main, menu);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onOptionsItemSelected(MenuItem item) {
|
public boolean onOptionsItemSelected(MenuItem item) {
|
||||||
// Handle action bar item clicks here. The action bar will
|
// Handle item selection
|
||||||
// automatically handle clicks on the Home/Up button, so long
|
switch (item.getItemId()) {
|
||||||
// as you specify a parent activity in AndroidManifest.xml.
|
case R.id.settings:
|
||||||
int id = item.getItemId();
|
settings();
|
||||||
|
return true;
|
||||||
//noinspection SimplifiableIfStatement
|
default:
|
||||||
if (id == R.string.action_settings) {
|
return super.onOptionsItemSelected(item);
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return super.onOptionsItemSelected(item);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -138,4 +174,12 @@ public class MainActivity extends AppCompatActivity {
|
|||||||
myWebView.restoreState(savedInstanceState);
|
myWebView.restoreState(savedInstanceState);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Called when the user taps the Send button */
|
||||||
|
public void settings() {
|
||||||
|
Intent intentSettings = new Intent(this, SettingsActivity.class);
|
||||||
|
intentSettings.putExtra(MESSAGE, MESSAGE);
|
||||||
|
startActivity(intentSettings);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,127 @@
|
|||||||
|
package de.weseng.wifiweatherstation;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.SharedPreferences;
|
||||||
|
import android.net.ConnectivityManager;
|
||||||
|
import android.net.NetworkInfo;
|
||||||
|
import android.support.v7.app.AppCompatActivity;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.KeyEvent;
|
||||||
|
import android.view.MenuItem;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.inputmethod.EditorInfo;
|
||||||
|
import android.widget.EditText;
|
||||||
|
import android.widget.TextView;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import static de.weseng.wifiweatherstation.MainActivity.PREFS_NAME;
|
||||||
|
|
||||||
|
public class SettingsActivity extends AppCompatActivity {
|
||||||
|
public static final String PREFS_NAME = "Settings";
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_settings);
|
||||||
|
|
||||||
|
// Get the Intent that started this activity and extract the string
|
||||||
|
Intent intent = getIntent();
|
||||||
|
String message = intent.getStringExtra(MainActivity.MESSAGE);
|
||||||
|
|
||||||
|
SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0);
|
||||||
|
String ssidLocal = settings.getString("ssidLocal", getString(R.string.ssid));
|
||||||
|
String urlLocal = settings.getString("urlLocal", getString(R.string.url_local));
|
||||||
|
String urlGlobal = settings.getString("urlGlobal", getString(R.string.url_global));
|
||||||
|
//message = message.concat("\nSSIDLocal: " + ssidLocal);
|
||||||
|
|
||||||
|
// Capture the layout's TextView and set the string as its text
|
||||||
|
TextView textView = findViewById(R.id.textView);
|
||||||
|
textView.setText(message);
|
||||||
|
|
||||||
|
final EditText editTextSsid = findViewById(R.id.editTextSsidLocal);
|
||||||
|
editTextSsid.setText(ssidLocal);
|
||||||
|
editTextSsid.setOnKeyListener(new View.OnKeyListener() {
|
||||||
|
public boolean onKey(View v, int keyCode, KeyEvent event) {
|
||||||
|
// If the event is a key-down event on the "enter" button
|
||||||
|
if ((event.getAction() == KeyEvent.ACTION_DOWN) &&
|
||||||
|
(keyCode == KeyEvent.KEYCODE_ENTER)) {
|
||||||
|
// Perform action on key press
|
||||||
|
String value = editTextSsid.getText().toString();
|
||||||
|
//Toast.makeText(getApplicationContext(), value, Toast.LENGTH_SHORT).show();
|
||||||
|
save("ssidLocal", value);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
final EditText editTextUrlLocal = findViewById(R.id.editTextUrlLocal);
|
||||||
|
editTextUrlLocal.setText(urlLocal);
|
||||||
|
editTextUrlLocal.setOnKeyListener(new View.OnKeyListener() {
|
||||||
|
public boolean onKey(View v, int keyCode, KeyEvent event) {
|
||||||
|
// If the event is a key-down event on the "enter" button
|
||||||
|
if ((event.getAction() == KeyEvent.ACTION_DOWN) &&
|
||||||
|
(keyCode == KeyEvent.KEYCODE_ENTER)) {
|
||||||
|
// Perform action on key press
|
||||||
|
String value = editTextUrlLocal.getText().toString();
|
||||||
|
//Toast.makeText(getApplicationContext(), value, Toast.LENGTH_SHORT).show();
|
||||||
|
save("urlLocal", value);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
final EditText editTextUrlGlobal = findViewById(R.id.editTextUrlGlobal);
|
||||||
|
editTextUrlGlobal.setText(urlGlobal);
|
||||||
|
editTextUrlGlobal.setOnKeyListener(new View.OnKeyListener() {
|
||||||
|
public boolean onKey(View v, int keyCode, KeyEvent event) {
|
||||||
|
// If the event is a key-down event on the "enter" button
|
||||||
|
if ((event.getAction() == KeyEvent.ACTION_DOWN) &&
|
||||||
|
(keyCode == KeyEvent.KEYCODE_ENTER)) {
|
||||||
|
// Perform action on key press
|
||||||
|
String value = editTextUrlGlobal.getText().toString();
|
||||||
|
//Toast.makeText(getApplicationContext(), value, Toast.LENGTH_SHORT).show();
|
||||||
|
save("urlGlobal", value);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onBackPressed() {
|
||||||
|
// This will be called either automatically for you on 2.0
|
||||||
|
// or later, or by the code above on earlier versions of the
|
||||||
|
// platform.
|
||||||
|
save_all();
|
||||||
|
super.onBackPressed();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onStop(){
|
||||||
|
super.onStop();
|
||||||
|
save_all();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void save_all() {
|
||||||
|
save("ssidLocal", ((EditText)findViewById(R.id.editTextSsidLocal)).getText().toString());
|
||||||
|
save("urlLocal", ((EditText)findViewById(R.id.editTextUrlLocal)).getText().toString());
|
||||||
|
save("urlGlobal", ((EditText)findViewById(R.id.editTextUrlGlobal)).getText().toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
public void save(String key, String value) {
|
||||||
|
// We need an Editor object to make preference changes.
|
||||||
|
// All objects are from android.context.Context
|
||||||
|
SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0);
|
||||||
|
SharedPreferences.Editor editor = settings.edit();
|
||||||
|
editor.putString(key, value);
|
||||||
|
|
||||||
|
// Commit the edits!
|
||||||
|
editor.commit();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -14,6 +14,6 @@
|
|||||||
app:layout_constraintBottom_toBottomOf="parent"
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
app:layout_constraintLeft_toLeftOf="parent"
|
app:layout_constraintLeft_toLeftOf="parent"
|
||||||
app:layout_constraintRight_toRightOf="parent"
|
app:layout_constraintRight_toRightOf="parent"
|
||||||
app:layout_constraintTop_toTopOf="parent"></WebView>
|
app:layout_constraintTop_toTopOf="parent"/>
|
||||||
|
|
||||||
</android.support.constraint.ConstraintLayout>
|
</android.support.constraint.ConstraintLayout>
|
||||||
75
app/src/main/res/layout/activity_settings.xml
Normal file
75
app/src/main/res/layout/activity_settings.xml
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
tools:context=".SettingsActivity">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/textView"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="16dp"
|
||||||
|
android:text="TextView"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toTopOf="parent" />
|
||||||
|
|
||||||
|
<android.support.design.widget.TextInputLayout
|
||||||
|
android:id="@+id/textInputLayoutSsidLocal"
|
||||||
|
android:layout_width="395dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="18dp"
|
||||||
|
app:hintAnimationEnabled="false"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toBottomOf="@+id/textView">
|
||||||
|
|
||||||
|
<android.support.design.widget.TextInputEditText
|
||||||
|
android:id="@+id/editTextSsidLocal"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:hint="SSID"
|
||||||
|
android:inputType="text" />
|
||||||
|
</android.support.design.widget.TextInputLayout>
|
||||||
|
|
||||||
|
<android.support.design.widget.TextInputLayout
|
||||||
|
android:id="@+id/textInputLayoutUrlLocal"
|
||||||
|
android:layout_width="395dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="8dp"
|
||||||
|
app:hintAnimationEnabled="false"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toBottomOf="@+id/textInputLayoutSsidLocal">
|
||||||
|
|
||||||
|
<android.support.design.widget.TextInputEditText
|
||||||
|
android:id="@+id/editTextUrlLocal"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:hint="Local URL"
|
||||||
|
android:inputType="text" />
|
||||||
|
</android.support.design.widget.TextInputLayout>
|
||||||
|
|
||||||
|
<android.support.design.widget.TextInputLayout
|
||||||
|
android:id="@+id/textInputLayoutUrlGlobal"
|
||||||
|
android:layout_width="395dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="8dp"
|
||||||
|
app:hintAnimationEnabled="false"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toBottomOf="@+id/textInputLayoutUrlLocal">
|
||||||
|
|
||||||
|
<android.support.design.widget.TextInputEditText
|
||||||
|
android:id="@+id/editTextUrlGlobal"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:hint="Global URL"
|
||||||
|
android:inputType="text" />
|
||||||
|
</android.support.design.widget.TextInputLayout>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</android.support.constraint.ConstraintLayout>
|
||||||
7
app/src/main/res/menu/main.xml
Normal file
7
app/src/main/res/menu/main.xml
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<menu xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<item android:id="@+id/settings"
|
||||||
|
android:title="@string/settings"/>
|
||||||
|
//android:icon="@drawable/ic_new_game"
|
||||||
|
//android:showAsAction="ifRoom"
|
||||||
|
</menu>
|
||||||
5
app/src/main/res/values-de/strings.xml
Normal file
5
app/src/main/res/values-de/strings.xml
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
<resources>
|
||||||
|
<string name="app_name">WiFi-Wetter-Station</string>
|
||||||
|
<string name="settings">Einstellungen</string>
|
||||||
|
<string name="loading">Bitte warten, die Ansicht wird geladen...</string>
|
||||||
|
</resources>
|
||||||
@@ -1,4 +1,8 @@
|
|||||||
<resources>
|
<resources>
|
||||||
<string name="app_name">WiFi Weather Station</string>
|
<string name="app_name">WiFi Weather Station</string>
|
||||||
<string name="action_settings">Einstellungen</string>
|
<string name="settings">Settings</string>
|
||||||
|
<string name="loading">Please wait, the view is loading...</string>
|
||||||
|
<string name="ssid" translatable="false">NETGEAR26-5G-2</string>
|
||||||
|
<string name="url_local" translatable="false">http://192.168.1.5/site/wifi-weather-station/</string>
|
||||||
|
<string name="url_global" translatable="false">http://inetsrv.no-ip.org/site/wifi-weather-station/</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|||||||
@@ -1,7 +1,8 @@
|
|||||||
<resources>
|
<resources>
|
||||||
|
|
||||||
<!-- Base application theme. -->
|
<!-- Base application theme. -->
|
||||||
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
|
<!--<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">-->
|
||||||
|
<style name="DarkTheme" parent="Theme.AppCompat">
|
||||||
<!-- Customize your theme here. -->
|
<!-- Customize your theme here. -->
|
||||||
<item name="colorPrimary">@color/colorPrimary</item>
|
<item name="colorPrimary">@color/colorPrimary</item>
|
||||||
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
|
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
|
||||||
|
|||||||
Reference in New Issue
Block a user