SocketHandler挪到业务模块
This commit is contained in:
@@ -1,83 +0,0 @@
|
||||
package com.mogo.cloud.socket;
|
||||
|
||||
import android.content.Context;
|
||||
import android.os.SystemClock;
|
||||
|
||||
import com.mogo.utils.network.utils.GsonUtil;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import static com.mogo.cloud.socket.WebSocketMsgType.MSG_TYPE_ACK;
|
||||
|
||||
/**
|
||||
* @author liujing
|
||||
* @description 描述
|
||||
* @since: 2021/1/22
|
||||
*/
|
||||
public class SocketHandler {
|
||||
private static volatile SocketHandler mInstance;
|
||||
private long serverTime = 0;
|
||||
private long receiveMsgTime = 0;
|
||||
private List<IMogoCloudSocketOnMessageListener> listenerList;
|
||||
|
||||
public static SocketHandler getInstance() {
|
||||
if (mInstance == null) {
|
||||
synchronized (SocketManager.class) {
|
||||
if (mInstance == null) {
|
||||
mInstance = new SocketHandler();
|
||||
}
|
||||
}
|
||||
}
|
||||
return mInstance;
|
||||
}
|
||||
|
||||
/*
|
||||
* useInner: 是否注册自己内部的监听
|
||||
* */
|
||||
public void initSocket(Context context, boolean useInner, String appId, IMogoCloudSocketOnMessageListener listener) {
|
||||
SocketManager.getInstance().init(context, appId);
|
||||
if (useInner) {
|
||||
SocketManager.getInstance().registerOnMessageListener(0x040002, onMessageListener);
|
||||
SocketManager.getInstance().registerOnMessageListener(0x040003, onMessageListener);
|
||||
} else {
|
||||
SocketManager.getInstance().registerOnMessageListener(0x040002, listener);
|
||||
SocketManager.getInstance().registerOnMessageListener(0x040003, listener);
|
||||
listenerList.add(listener);
|
||||
}
|
||||
}
|
||||
|
||||
private final IMogoCloudSocketOnMessageListener<String> onMessageListener = new IMogoCloudSocketOnMessageListener<String>() {
|
||||
@Override
|
||||
public Class<String> target() {
|
||||
return String.class;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onMsgReceived(String message) {
|
||||
WebSocketData webSocketData = GsonUtil.objectFromJson(message, WebSocketData.class);
|
||||
int msgType = webSocketData.getMsgType();
|
||||
if (msgType == MSG_TYPE_ACK.getMsgType()) {
|
||||
if (webSocketData.getUtcTime() > 0) {
|
||||
serverTime = webSocketData.getUtcTime();
|
||||
receiveMsgTime = SystemClock.elapsedRealtime();
|
||||
if (webSocketData.getUpUtcTime() > 0) {
|
||||
long nextDelay = webSocketData.getUpUtcTime() - serverTime;
|
||||
//todo
|
||||
// MogoRTKLocation.getInstance().resetUploadDelay(nextDelay);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
public void stop() {
|
||||
//todo
|
||||
// MogoRTKLocation.getInstance().unregisterRTKLocationListener();
|
||||
// MogoRTKLocation.getInstance().stop();
|
||||
for (int i = 0; i < listenerList.size(); i++) {
|
||||
SocketManager.getInstance().unregisterOnMessageListener(0x040002, listenerList.get(i));
|
||||
SocketManager.getInstance().unregisterOnMessageListener(0x040003, listenerList.get(i));
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user