Compare commits
12 Commits
3f96055a6e
...
fix/SD-216
Author | SHA1 | Date | |
---|---|---|---|
3a0fe96708 | |||
5cd598bec9 | |||
79234c9830 | |||
cbeb912820 | |||
f15688b9a1 | |||
3935b3ad0b | |||
e59b522ccb | |||
94091a9a31 | |||
d9d325b18b | |||
f4c6b8163d | |||
17a7e1711e | |||
9b302d0461 |
@ -28,13 +28,11 @@ public class TCPService extends Service {
|
||||
int port = 13589;
|
||||
try {
|
||||
port = Integer.parseInt(AppParams.PORT);
|
||||
}
|
||||
catch(Exception ex) { }
|
||||
} catch(Exception ex) { }
|
||||
|
||||
tcpParser = new TCPmsgParser();
|
||||
|
||||
if(tcp == null && !AppParams.IP.equalsIgnoreCase("n/a"))
|
||||
{
|
||||
if(tcp == null && !AppParams.IP.equalsIgnoreCase("n/a")) {
|
||||
tcp = new TCPhandler(getApplicationContext(), AppParams.IP, port);
|
||||
}
|
||||
|
||||
|
@ -5,7 +5,6 @@ import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.content.IntentFilter;
|
||||
import android.net.ConnectivityManager;
|
||||
import android.net.NetworkInfo;
|
||||
import android.net.wifi.WifiManager;
|
||||
|
||||
import com.safemobile.lib.AppParams;
|
||||
@ -38,21 +37,19 @@ public class TCPhandler implements Runnable {
|
||||
private String leftOver = "";
|
||||
|
||||
public static LinkedList<TCPmsg> msgList;
|
||||
private volatile int n = 0;
|
||||
|
||||
public Boolean isConnectionUP = false;
|
||||
public Boolean previousConnectionWasUP = false;
|
||||
|
||||
private Context context;
|
||||
private boolean isWiFiOn = true;
|
||||
private final Context context;
|
||||
private boolean isWiFiOn;
|
||||
|
||||
public TCPhandler(Context context, String hostName, int p) {
|
||||
|
||||
this.context = context;
|
||||
serverHostname = hostName;
|
||||
port = p;
|
||||
|
||||
msgList = new LinkedList<TCPmsg>();
|
||||
msgList = new LinkedList<>();
|
||||
SM.Debug("---TCPhandler constructor [" + hostName + "," + p + "] ---");
|
||||
listenThread = new Thread(this, "TCPlisten");
|
||||
listenThread.start(); // (2) Start the thread.
|
||||
@ -64,7 +61,6 @@ public class TCPhandler implements Runnable {
|
||||
public void run() {
|
||||
try {
|
||||
previousConnectionWasUP = isConnectionUP;
|
||||
|
||||
// try to send something
|
||||
TCPmsgParser._fireonTCPConnectionStatusEvent(isConnectionUP, previousConnectionWasUP);
|
||||
} catch (Exception e) {
|
||||
@ -74,16 +70,18 @@ public class TCPhandler implements Runnable {
|
||||
}, 0, 3000);
|
||||
|
||||
// get WiFi state
|
||||
ConnectivityManager connManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||
NetworkInfo mWifi = connManager.getNetworkInfo(ConnectivityManager.TYPE_WIFI);
|
||||
if (mWifi.isConnectedOrConnecting())
|
||||
isWiFiOn = true;
|
||||
isWiFiOn = isNetworkConnected();
|
||||
|
||||
IntentFilter intentFilter = new IntentFilter();
|
||||
intentFilter.addAction(WifiManager.NETWORK_STATE_CHANGED_ACTION);
|
||||
context.registerReceiver(mReceived, intentFilter);
|
||||
}
|
||||
|
||||
private boolean isNetworkConnected() {
|
||||
ConnectivityManager cm = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||
return cm.getActiveNetworkInfo() != null && cm.getActiveNetworkInfo().isConnected();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void run() {
|
||||
try {
|
||||
@ -100,20 +98,19 @@ public class TCPhandler implements Runnable {
|
||||
isConnectionUP = true;
|
||||
triggerTCPConnectionStateEvent();
|
||||
}
|
||||
|
||||
} catch (UnknownHostException e) {
|
||||
SM.Debug("UnknownHostException", "TCPhandler break:" + e.toString());
|
||||
SM.Debug("UnknownHostException", "TCPhandler break:"+ e);
|
||||
} catch (IllegalArgumentException e) {
|
||||
SM.Debug("IllegalArgumentException", "TCPhandler break:" + e.toString());
|
||||
SM.Debug("IllegalArgumentException", "TCPhandler break:"+ e);
|
||||
} catch (IOException e) {
|
||||
SM.Debug("IOException", "TCPhandler break:" + e.toString());
|
||||
SM.Debug("IOException", "TCPhandler break:"+ e);
|
||||
}
|
||||
|
||||
while (alive) {
|
||||
try {
|
||||
Thread.sleep(3000);
|
||||
} catch (InterruptedException e) {
|
||||
SM.Debug("TCPhandler Crash1 on sleep:" + e.toString());
|
||||
SM.Debug("TCPhandler Crash1 on sleep:"+ e);
|
||||
}
|
||||
|
||||
while (Boolean.TRUE.equals(isConnectionUP)) {
|
||||
@ -166,7 +163,7 @@ public class TCPhandler implements Runnable {
|
||||
//end process leftover
|
||||
|
||||
String data = "";
|
||||
n = 0;
|
||||
int n = 0;
|
||||
|
||||
byte[] buf = new byte[1024];
|
||||
// read data into buffer
|
||||
@ -181,7 +178,6 @@ public class TCPhandler implements Runnable {
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
byte[] temp = new byte[n];
|
||||
if (n >= 0) System.arraycopy(buf, 0, temp, 0, n);
|
||||
|
||||
@ -191,8 +187,7 @@ public class TCPhandler implements Runnable {
|
||||
data = new String(temp);
|
||||
|
||||
//if we have any leftovers from previous message add them
|
||||
if (leftOver.length() > 1) // avoid case with only one #
|
||||
{
|
||||
if(leftOver.length() > 1) { // avoid case with only one #
|
||||
data = leftOver+data;
|
||||
leftOver = "";
|
||||
}
|
||||
@ -217,13 +212,14 @@ public class TCPhandler implements Runnable {
|
||||
}
|
||||
char[] temMSG = data.toCharArray();
|
||||
if (data.length() != messLen) {
|
||||
//if expected string message is smaller then actual string then exit processing;
|
||||
if (messLen > data.length()) {
|
||||
leftOver = data; // Add by bigu
|
||||
continue;
|
||||
}
|
||||
//perform cut
|
||||
temMSG = data.substring(0,messLen).toCharArray();
|
||||
leftOver = data.substring(messLen, data.length());
|
||||
leftOver = data.substring(messLen);
|
||||
}
|
||||
//decode TCP msg
|
||||
TCPmsg msg = new TCPmsg(temMSG);
|
||||
@ -234,33 +230,28 @@ public class TCPhandler implements Runnable {
|
||||
prioritizePongReceived();
|
||||
|
||||
msgList.add(msg);
|
||||
|
||||
} catch(Exception ex) {
|
||||
SM.Debug("TCPHandler", "TCPhandler/run/break:" + ex.toString());
|
||||
SM.Debug("TCPHandler", "TCPhandler/run/break:"+ ex);
|
||||
isConnectionUP = false;
|
||||
triggerTCPConnectionStateEvent();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
//
|
||||
try {
|
||||
Thread.sleep(1000);
|
||||
} catch (InterruptedException e) {
|
||||
SM.Debug("TCPhandler Crash2 on sleep:" + e.toString());
|
||||
SM.Debug("TCPhandler Crash2 on sleep:"+ e);
|
||||
}
|
||||
|
||||
//try to restart connection
|
||||
if (alive && isWiFiOn)
|
||||
restartTCP();
|
||||
|
||||
}
|
||||
SM.Debug("==================================");
|
||||
SM.Debug("TCP listenThread stoped!! alive = false");
|
||||
SM.Debug("==================================");
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a bypass in order to trigger the ping received event
|
||||
*/
|
||||
@ -268,7 +259,6 @@ public class TCPhandler implements Runnable {
|
||||
TCPmsgParser._firePONGReceivedEvent();
|
||||
}
|
||||
|
||||
|
||||
/* Broadcast Received for WiFi Connect/Disconnect */
|
||||
public BroadcastReceiver mReceived = new BroadcastReceiver() {
|
||||
|
||||
@ -278,22 +268,16 @@ public class TCPhandler implements Runnable {
|
||||
SM.Debug("WIFI STATE", action);
|
||||
|
||||
if (action.equals(WifiManager.NETWORK_STATE_CHANGED_ACTION)){
|
||||
NetworkInfo info = intent.getParcelableExtra(WifiManager.EXTRA_NETWORK_INFO);
|
||||
// close socket if the wifi is disconnecting or disconnected
|
||||
if (!info.isConnectedOrConnecting()) {
|
||||
isWiFiOn = isNetworkConnected();
|
||||
if (!isWiFiOn)
|
||||
closeSocket();
|
||||
isWiFiOn = false;
|
||||
} else
|
||||
isWiFiOn = true;
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* Send a message through the TCP Socket
|
||||
*
|
||||
* @param seqID The messages's sequence id (a number of order)
|
||||
/** Send a message through the TCP Socket
|
||||
* @param seqID The messages's sequence ID (a number of order)
|
||||
* @param msg The messages which will be sent
|
||||
* @return True if the message was sent
|
||||
*/
|
||||
@ -339,51 +323,28 @@ public class TCPhandler implements Runnable {
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
public void setConnectionIsDown() {
|
||||
if (input != null) {
|
||||
try {
|
||||
input.close();
|
||||
} catch (IOException e) {
|
||||
} finally {
|
||||
input = null;
|
||||
}
|
||||
}
|
||||
|
||||
isConnectionUP = false;
|
||||
}
|
||||
|
||||
/* Encrypt a string using an encryption algorithm,
|
||||
* in this case TEA */
|
||||
public static byte[] encryptTEA(String toEncryptData) {
|
||||
byte[] encryptedByteArray = new byte[]{};
|
||||
|
||||
// no encryption
|
||||
encryptedByteArray = toEncryptData.getBytes();
|
||||
|
||||
return encryptedByteArray;
|
||||
return toEncryptData.getBytes();
|
||||
}
|
||||
|
||||
/* Decrypt a string using an encryption algorithm,
|
||||
* in this case TEA */
|
||||
public static byte[] decryptTEA(byte[] toDecryptData) {
|
||||
byte[] decryptedByteArray = new byte[]{};
|
||||
byte[] decryptedByteArray;
|
||||
|
||||
// no decryption
|
||||
decryptedByteArray = toDecryptData;
|
||||
|
||||
return decryptedByteArray;
|
||||
}
|
||||
|
||||
|
||||
public int getPort() {
|
||||
return port;
|
||||
}
|
||||
|
||||
public void updateTCPparameters(String ip, String _port) {
|
||||
|
||||
// stop socket
|
||||
try {
|
||||
if (soc != null)
|
||||
@ -395,9 +356,8 @@ public class TCPhandler implements Runnable {
|
||||
serverHostname = ip;
|
||||
try {
|
||||
port = Integer.parseInt(_port);
|
||||
} catch (Exception e) {
|
||||
|
||||
} finally {
|
||||
} catch (Exception ignored) { }
|
||||
finally {
|
||||
port = 13589;
|
||||
}
|
||||
}
|
||||
@ -438,23 +398,11 @@ public class TCPhandler implements Runnable {
|
||||
SM.Exception("restartTCP break:" + e.toString());
|
||||
isConnectionUP = false;
|
||||
}
|
||||
|
||||
triggerTCPConnectionStateEvent();
|
||||
}
|
||||
|
||||
public boolean isAlive() {
|
||||
return alive;
|
||||
}
|
||||
|
||||
public void setAlive(boolean alive) {
|
||||
this.alive = alive;
|
||||
}
|
||||
|
||||
/**
|
||||
* close Socket when unReachable
|
||||
*/
|
||||
/** close Socket when unReachable */
|
||||
public void closeSocket() {
|
||||
|
||||
try {
|
||||
input = null;
|
||||
output = null;
|
||||
@ -470,12 +418,10 @@ public class TCPhandler implements Runnable {
|
||||
SM.Debug("Stopping TCP", "TCP Connection is stopping on " + AppParams.IP + ":" + port);
|
||||
alive = false;
|
||||
|
||||
|
||||
if (mReceived!= null)
|
||||
try {
|
||||
context.unregisterReceiver(mReceived);
|
||||
} catch(Exception ex) {/* receiver not registered //*/}
|
||||
;
|
||||
|
||||
// stop thread
|
||||
if (listenThread != null) {
|
||||
@ -484,7 +430,6 @@ public class TCPhandler implements Runnable {
|
||||
moribund.interrupt();
|
||||
}
|
||||
|
||||
|
||||
if (input != null) {
|
||||
try {
|
||||
input.close();
|
||||
@ -508,9 +453,8 @@ public class TCPhandler implements Runnable {
|
||||
soc.close();
|
||||
soc = null;
|
||||
} catch (IOException e) {
|
||||
SM.Exception("TCPClient[STOP]", "Stop break:" + e.toString());
|
||||
SM.Exception("TCPClient[STOP]", "Stop break:"+ e);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
BIN
safeDispatch/release/SafeDispatchMobile_v.8.0.49-release.aab
Normal file
BIN
safeDispatch/release/SafeDispatchMobile_v.8.0.49-release.aab
Normal file
Binary file not shown.
@ -3,6 +3,7 @@ package com.safemobile.safedispatch;
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.appcompat.app.AppCompatActivity;
|
||||
|
||||
import android.app.AlertDialog;
|
||||
import android.app.DatePickerDialog;
|
||||
import android.app.Dialog;
|
||||
import android.graphics.Color;
|
||||
@ -124,6 +125,18 @@ public class HistoryActivity extends AppCompatActivity implements OnMapReadyCall
|
||||
googleMap.moveCamera(CameraUpdateFactory.newLatLngZoom(latLng, 14));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onBackPressed() {
|
||||
AlertDialog.Builder builder = new AlertDialog.Builder(this);
|
||||
builder.setMessage(getString(R.string.exit))
|
||||
.setCancelable(false)
|
||||
.setNeutralButton(getString(R.string.logout), (dialog, id) -> parentTab.whenBackPressed(AppParams.ActivityResult.logout))
|
||||
.setPositiveButton(getString(R.string.ext), (dialog, id) -> parentTab.whenBackPressed(AppParams.ActivityResult.exit))
|
||||
.setNegativeButton(getString(R.string.cancel), (dialog, id) -> dialog.cancel());
|
||||
AlertDialog alert = builder.create();
|
||||
alert.show();
|
||||
}
|
||||
|
||||
private void setDate() {
|
||||
Calendar calendar = Calendar.getInstance();
|
||||
endDate = calendar.getTime();
|
||||
|
@ -42,6 +42,7 @@ public class RecordingsActivity extends Activity {
|
||||
private GridView gridView;
|
||||
private RecordingsGridViewAdapter adapter;
|
||||
private View convertViewRecording;
|
||||
private boolean isRecordingPlaying = false;
|
||||
|
||||
private int playingPosition = -1;
|
||||
|
||||
@ -89,6 +90,7 @@ public class RecordingsActivity extends Activity {
|
||||
gridView.setAdapter(adapter);
|
||||
|
||||
gridView.setOnItemClickListener(onItemClickListener);
|
||||
gridView.setOnTouchListener((v, event) -> isRecordingPlaying);
|
||||
|
||||
if (recHandle == null && !AppParams.DEMO)
|
||||
recHandle = new RecordingHandle(AppParams.IP);
|
||||
@ -171,12 +173,17 @@ public class RecordingsActivity extends Activity {
|
||||
SM.Debug("onResume");
|
||||
}
|
||||
|
||||
|
||||
|
||||
private final OnItemClickListener onItemClickListener = new OnItemClickListener() {
|
||||
@Override
|
||||
public void onItemClick(AdapterView<?> arg0, View view, int position, long arg3) {
|
||||
|
||||
// disable grid scrolling and item click
|
||||
gridView.setEnabled(false);
|
||||
if (isRecordingPlaying)
|
||||
return;
|
||||
|
||||
isRecordingPlaying = true;
|
||||
setConvertViewRecording(view);
|
||||
|
||||
// change background to playing
|
||||
@ -262,7 +269,7 @@ public class RecordingsActivity extends Activity {
|
||||
adapter.changePlaying(getPlayingPosition(), false);
|
||||
|
||||
// enable grid
|
||||
gridView.setEnabled(true);
|
||||
isRecordingPlaying = false;
|
||||
|
||||
// set playing Recording position to -1
|
||||
setPlayingPosition(-1);
|
||||
|
@ -233,10 +233,10 @@ public class SDMobileActivity extends Activity {
|
||||
etPassword.setText(AppParams.PASSWORD.equalsIgnoreCase("n/a") ? "" : AppParams.PASSWORD);
|
||||
}
|
||||
|
||||
layoutTCP = (RelativeLayout) findViewById(R.id.layoutTCP);
|
||||
layoutTCP = findViewById(R.id.layoutTCP);
|
||||
|
||||
llUsername = (LinearLayout) findViewById(R.id.llUsername);
|
||||
llPassword = (LinearLayout) findViewById(R.id.llPassword);
|
||||
llUsername = findViewById(R.id.llUsername);
|
||||
llPassword = findViewById(R.id.llPassword);
|
||||
|
||||
// enable ui after the language is changed and tcp connection is on
|
||||
if (tcp != null && tcp.isConnectionUP) {
|
||||
@ -663,7 +663,7 @@ public class SDMobileActivity extends Activity {
|
||||
// get default password
|
||||
AppParams.PASSWORD = AppParams.prefs.getString(PASSWORD, "n/a");
|
||||
// get default IP
|
||||
AppParams.IP = AppParams.prefs.getString("ip", "192.168.2.100");
|
||||
AppParams.IP = AppParams.prefs.getString("ip", "185.8.154.190");
|
||||
|
||||
// get Radio ID & IP
|
||||
AppParams.RADIOID = AppParams.prefs.getInt("radioId", 100);
|
||||
@ -737,10 +737,10 @@ public class SDMobileActivity extends Activity {
|
||||
Dialog dialogInfo = new Dialog(context);
|
||||
dialogInfo.requestWindowFeature(Window.FEATURE_NO_TITLE);
|
||||
dialogInfo.setContentView(R.layout.dialog_login);
|
||||
TextView textTitle = (TextView) dialogInfo.findViewById(R.id.textTitle);
|
||||
TextView text = (TextView) dialogInfo.findViewById(R.id.text);
|
||||
TextView text2 = (TextView) dialogInfo.findViewById(R.id.text2);
|
||||
ImageView image = (ImageView) dialogInfo.findViewById(R.id.image);
|
||||
TextView textTitle = dialogInfo.findViewById(R.id.textTitle);
|
||||
TextView text = dialogInfo.findViewById(R.id.text);
|
||||
TextView text2 = dialogInfo.findViewById(R.id.text2);
|
||||
ImageView image = dialogInfo.findViewById(R.id.image);
|
||||
|
||||
textTitle.setText(getString(R.string.connectionError));
|
||||
image.setImageResource(R.drawable.error);
|
||||
|
@ -35,6 +35,6 @@
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_weight="0"
|
||||
android:background="@drawable/checked">
|
||||
</LinearLayout>
|
||||
android:background="@drawable/checked"
|
||||
android:orientation="horizontal" />
|
||||
</LinearLayout>
|
@ -32,7 +32,6 @@
|
||||
android:layout_height="wrap_content"
|
||||
android:text="@string/serverIP"
|
||||
android:textAppearance="?android:attr/textAppearanceMedium"
|
||||
android:textColor="#FFFFFF"
|
||||
android:textStyle="bold"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:gravity="center_vertical|right"
|
||||
@ -67,7 +66,6 @@
|
||||
android:layout_height="wrap_content"
|
||||
android:text="@string/serverPort"
|
||||
android:textAppearance="?android:attr/textAppearanceMedium"
|
||||
android:textColor="#FFFFFF"
|
||||
android:textStyle="bold"
|
||||
android:gravity="center_vertical|right"
|
||||
android:layout_gravity="center_vertical|right"
|
||||
@ -112,7 +110,6 @@
|
||||
android:layout_height="wrap_content"
|
||||
android:text="@string/configName"
|
||||
android:textAppearance="?android:attr/textAppearanceMedium"
|
||||
android:textColor="#FFFFFF"
|
||||
android:textStyle="bold"
|
||||
android:gravity="center_vertical|right"
|
||||
android:layout_gravity="center_vertical"/>
|
||||
@ -181,7 +178,6 @@
|
||||
android:text="@string/language"
|
||||
android:textAppearance="?android:attr/textAppearanceMedium"
|
||||
android:textStyle="bold"
|
||||
android:textColor="#FFFFFF"
|
||||
android:gravity="right"
|
||||
android:layout_gravity="center_vertical"/>
|
||||
<LinearLayout
|
||||
|
@ -11,5 +11,5 @@
|
||||
android:layout_width="fill_parent"
|
||||
android:id="@+id/balloon_vehicle_name"
|
||||
android:textSize="12dip"
|
||||
android:textColor="#FF000000"></TextView>
|
||||
android:textColor="#FF000000" />
|
||||
</LinearLayout>
|
||||
|
@ -1,12 +1,13 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
<LinearLayout
|
||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:id="@+id/layout_root"
|
||||
android:orientation="horizontal"
|
||||
android:layout_width="fill_parent"
|
||||
android:layout_height="fill_parent"
|
||||
android:padding="10dp"
|
||||
>
|
||||
<ImageView android:id="@+id/image"
|
||||
android:padding="10dp" >
|
||||
<ImageView
|
||||
android:id="@+id/image"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginRight="10dp"
|
||||
@ -19,19 +20,19 @@
|
||||
android:orientation="vertical"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:gravity="center_vertical">
|
||||
<TextView android:id="@+id/text"
|
||||
<TextView
|
||||
android:id="@+id/text"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:paddingTop="8dp"
|
||||
android:textSize="18dp"
|
||||
android:textColor="@color/black"
|
||||
/>
|
||||
<TextView android:id="@+id/text2"
|
||||
<TextView
|
||||
android:id="@+id/text2"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:paddingTop="8dp"
|
||||
android:textSize="18dp"
|
||||
android:textColor="@color/black"
|
||||
/>
|
||||
</LinearLayout>
|
||||
</LinearLayout>
|
||||
|
@ -40,7 +40,6 @@
|
||||
android:paddingTop="8dp"
|
||||
android:text="Row1"
|
||||
android:textAppearance="?android:attr/textAppearanceLarge"
|
||||
android:textColor="@color/black"
|
||||
/>
|
||||
<TextView android:id="@+id/text2"
|
||||
android:layout_width="wrap_content"
|
||||
@ -48,7 +47,6 @@
|
||||
android:paddingTop="8dp"
|
||||
android:textAppearance="?android:attr/textAppearanceMedium"
|
||||
android:text="Row2"
|
||||
android:textColor="@color/black"
|
||||
/>
|
||||
</LinearLayout>
|
||||
</LinearLayout>
|
||||
|
@ -210,8 +210,6 @@
|
||||
</LinearLayout>
|
||||
</LinearLayout>
|
||||
|
||||
|
||||
|
||||
<RelativeLayout
|
||||
android:id="@+id/frameLayoutLanguage"
|
||||
android:layout_width="wrap_content"
|
||||
@ -221,11 +219,7 @@
|
||||
android:layout_alignParentBottom="true"
|
||||
android:layout_gravity="right"
|
||||
android:paddingBottom="6dp"
|
||||
android:layout_toLeftOf="@+id/frameLayout13">
|
||||
</RelativeLayout>
|
||||
|
||||
|
||||
|
||||
android:layout_toLeftOf="@+id/frameLayout13" />
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/imageLoading"
|
||||
|
@ -35,6 +35,6 @@
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_weight="0"
|
||||
android:background="@drawable/checked">
|
||||
</LinearLayout>
|
||||
android:background="@drawable/checked"
|
||||
android:orientation="horizontal" />
|
||||
</LinearLayout>
|
@ -9,7 +9,6 @@
|
||||
style="?header"
|
||||
android:gravity="center_vertical" >
|
||||
|
||||
|
||||
<TextView
|
||||
android:layout_width="fill_parent"
|
||||
android:layout_height="wrap_content"
|
||||
|
@ -67,7 +67,6 @@
|
||||
android:visibility="invisible"
|
||||
android:background="@drawable/addmessage_selector"/>
|
||||
|
||||
<!-- android:background="@drawable/addmessage_selector" -->
|
||||
</LinearLayout>
|
||||
<LinearLayout
|
||||
android:layout_width="fill_parent"
|
||||
|
@ -123,7 +123,6 @@
|
||||
android:textSize="16dp"
|
||||
android:paddingTop="7dp" />
|
||||
</LinearLayout>
|
||||
<!-- android:background="@drawable/addmessage_selector" -->
|
||||
</LinearLayout>
|
||||
|
||||
<LinearLayout
|
||||
@ -204,8 +203,7 @@
|
||||
android:id="@+id/imageViewStatus2"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="fill_parent"
|
||||
android:src="@drawable/status_offline"
|
||||
/>
|
||||
android:src="@drawable/status_offline" />
|
||||
</LinearLayout>
|
||||
</LinearLayout>
|
||||
|
||||
@ -239,7 +237,6 @@
|
||||
android:layout_height="wrap_content"
|
||||
android:text="@string/Zone"
|
||||
android:textStyle="bold"
|
||||
android:textColor="#ffffffff"
|
||||
android:textAppearance="?android:attr/textAppearanceMedium"/>
|
||||
<LinearLayout
|
||||
android:id="@+id/layoutSpinnerZone"
|
||||
@ -279,7 +276,6 @@
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="@string/Channel"
|
||||
android:textColor="#ffffffff"
|
||||
android:textStyle="bold"
|
||||
android:textAppearance="?android:attr/textAppearanceMedium"/>
|
||||
|
||||
@ -376,7 +372,8 @@
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:orientation="vertical">
|
||||
<RadioGroup android:id="@+id/radioGroupCallType"
|
||||
<RadioGroup
|
||||
android:id="@+id/radioGroupCallType"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginBottom="3sp">
|
||||
@ -388,7 +385,7 @@
|
||||
android:checked="true"
|
||||
android:text="@string/AllCall"
|
||||
android:textAppearance="?android:attr/textAppearanceMedium"
|
||||
android:textColor="#ffffffff" />
|
||||
/>
|
||||
|
||||
<RadioButton
|
||||
android:id="@+id/radioGroup"
|
||||
@ -396,7 +393,7 @@
|
||||
android:layout_height="30dp"
|
||||
android:text="@string/GroupCall"
|
||||
android:textAppearance="?android:attr/textAppearanceMedium"
|
||||
android:textColor="#ffffffff" />
|
||||
/>
|
||||
|
||||
<RadioButton
|
||||
android:id="@+id/radioPrivate"
|
||||
@ -404,7 +401,7 @@
|
||||
android:layout_height="30dp"
|
||||
android:text="@string/PrivateCall"
|
||||
android:textAppearance="?android:attr/textAppearanceMedium"
|
||||
android:textColor="#ffffffff" />
|
||||
/>
|
||||
|
||||
</RadioGroup>
|
||||
<LinearLayout
|
||||
@ -463,7 +460,6 @@
|
||||
android:text="@string/DeKey"
|
||||
android:textSize="18dp" />
|
||||
</LinearLayout>
|
||||
|
||||
</LinearLayout>
|
||||
</LinearLayout>
|
||||
</LinearLayout>
|
@ -123,7 +123,6 @@
|
||||
android:visibility="gone"
|
||||
android:background="@drawable/recycle"/>
|
||||
|
||||
<!-- android:background="@drawable/addmessage_selector" -->
|
||||
</LinearLayout>
|
||||
|
||||
<GridView
|
||||
|
@ -1,5 +1,6 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
<LinearLayout
|
||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:id="@+id/layoutMain"
|
||||
android:layout_width="fill_parent"
|
||||
android:layout_height="fill_parent"
|
||||
@ -34,7 +35,6 @@
|
||||
android:layout_height="wrap_content"
|
||||
android:text="@string/serverIP"
|
||||
android:textSize="14dp"
|
||||
android:textColor="#FFFFFF"
|
||||
android:textStyle="bold"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:gravity="center_vertical|right"
|
||||
@ -69,7 +69,6 @@
|
||||
android:layout_height="wrap_content"
|
||||
android:text="@string/serverPort"
|
||||
android:textSize="14dp"
|
||||
android:textColor="#FFFFFF"
|
||||
android:textStyle="bold"
|
||||
android:gravity="center_vertical|right"
|
||||
android:layout_gravity="center_vertical|right"
|
||||
@ -88,13 +87,11 @@
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_gravity="center_vertical|right"
|
||||
android:inputType="number"
|
||||
android:imeOptions="actionDone">
|
||||
</EditText>
|
||||
android:imeOptions="actionDone" />
|
||||
</LinearLayout>
|
||||
</LinearLayout>
|
||||
</LinearLayout>
|
||||
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="fill_parent"
|
||||
android:layout_height="wrap_content"
|
||||
@ -115,7 +112,6 @@
|
||||
android:layout_height="wrap_content"
|
||||
android:text="@string/configName"
|
||||
android:textSize="14dp"
|
||||
android:textColor="#FFFFFF"
|
||||
android:textStyle="bold"
|
||||
android:gravity="center_vertical|right"
|
||||
android:layout_gravity="center_vertical"/>
|
||||
@ -138,7 +134,6 @@
|
||||
android:singleLine="true" >
|
||||
<requestFocus />
|
||||
</EditText>
|
||||
|
||||
</LinearLayout>
|
||||
<LinearLayout
|
||||
android:layout_height="wrap_content"
|
||||
@ -168,7 +163,6 @@
|
||||
android:src="@drawable/questionmark_small" />
|
||||
</LinearLayout>
|
||||
</LinearLayout>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
<LinearLayout
|
||||
@ -184,7 +178,6 @@
|
||||
android:text="@string/language"
|
||||
android:textSize="14dp"
|
||||
android:layout_marginRight="2dp"
|
||||
android:textColor="#FFFFFF"
|
||||
android:textStyle="bold"
|
||||
android:gravity="right"
|
||||
android:layout_gravity="center_vertical"/>
|
||||
@ -249,7 +242,6 @@
|
||||
</LinearLayout>
|
||||
<RelativeLayout
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content">
|
||||
android:layout_height="wrap_content"/>
|
||||
|
||||
</RelativeLayout>
|
||||
</LinearLayout>
|
Reference in New Issue
Block a user