562935844@qq.com
2022-05-13 a3f9e5ce8dce3d86a60a79b85ce44424a612c6fa
HDLSDK/app/src/main/java/com/hdl/hdlsdk/MainActivity.java
@@ -10,7 +10,6 @@
import androidx.recyclerview.widget.RecyclerView;
import android.Manifest;
import android.content.Intent;
import android.os.Build;
import android.os.Bundle;
import android.text.TextUtils;
@@ -21,46 +20,30 @@
import com.chad.library.adapter.base.BaseQuickAdapter;
import com.chad.library.adapter.base.listener.OnItemClickListener;
import com.google.gson.JsonObject;
import com.google.gson.reflect.TypeToken;
import com.hdl.hdlsdk.device.DevicesListActivity;
import com.hdl.sdk.common.config.TopicConstant;
import com.hdl.sdk.common.event.EventListener;
import com.hdl.sdk.common.exception.HDLLinkException;
import com.hdl.sdk.common.utils.IdUtils;
import com.hdl.sdk.common.utils.IpUtils;
import com.hdl.sdk.common.utils.LogUtils;
import com.hdl.sdk.common.utils.gson.GsonConvert;
import com.hdl.sdk.connect.HDLLink;
import com.hdl.sdk.connect.bean.LinkRequest;
import com.hdl.sdk.connect.bean.LinkResponse;
import com.hdl.sdk.connect.bean.request.AuthenticateRequest;
import com.hdl.sdk.connect.bean.request.BroadcastRequest;
import com.hdl.sdk.connect.bean.request.PropertyReadRequest;
import com.hdl.sdk.connect.bean.response.BaseLocalResponse;
import com.hdl.sdk.connect.bean.response.GatewaySearchBean;
import com.hdl.sdk.connect.callback.HDLLinkCallBack;
import com.hdl.sdk.connect.callback.HDLLinkResponseCallBack;
import com.hdl.sdk.connect.config.HDLLinkConfig;
import com.hdl.sdk.connect.socket.HDLAuthSocket;
import com.hdl.sdk.connect.socket.HDLSocket;
import com.hdl.sdk.connect.bean.request.DeviceControlRequest;
import com.hdl.sdk.connect.protocol.LinkMessageDecoder;
import com.hdl.sdk.connect.protocol.LinkMessageEncoder;
import com.hdl.sdk.socket.SocketOptions;
import com.hdl.sdk.socket.codec.MessagePipeLine;
import java.util.Base64;
import com.hdl.sdk.socket.SocketBoot;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.ArrayList;
import java.util.Base64;
import java.util.List;
import java.util.Map;
import static com.hdl.sdk.common.config.TopicConstant.GATEWAY_SEARCH_REPLY;
import static java.util.Base64.*;
public class MainActivity extends AppCompatActivity {
@@ -71,18 +54,19 @@
    private TextView responseTv;
    boolean isOn;
    private EventListener allTopicsListener;
    private String testLightSid = "0001010D48C71B02020100010101";
    private String testLightSid = "1493092497588469761";
    @Override
    protected void onDestroy() {
        super.onDestroy();
        removeAllTopicsListener();
    }
void init() {
//    HDLLinkConfig.getInstance().setLocalSecret("7d04c4e3c2b7d600");
//    HDLLinkConfig.getInstance().setGatewayId("1473119283609321473");
//    HDLLinkConfig.getInstance().setLocalEncrypt(true);
        HDLLinkConfig.getInstance().setLocalSecret("e186beeb7974998e");
        HDLLinkConfig.getInstance().setGatewayId("1519863101509361666");
}
    @RequiresApi(api = Build.VERSION_CODES.O)
    @Override
    protected void onCreate(Bundle savedInstanceState) {
@@ -94,7 +78,7 @@
        rv = findViewById(R.id.rv);
        rv.setLayoutManager(new LinearLayoutManager(this));
         init();
//        init();
        checkIfCertified();
        initDeviceInfo();//初始化基本信息,非常重要,认证时要用
        registerAllTopicsListener();
@@ -170,7 +154,7 @@
                        break;
                    case 8:
                        //功能列表
                        startDevicesListActivity();
//                        startDevicesListActivity();
                        break;
                    case 9:
                        //UDP发送
@@ -206,6 +190,7 @@
        String mes = isCertified ? "已经认证过" : "未认证";
        showToast(mes);
        tv.setText(mes);
    }
    /**
@@ -265,22 +250,23 @@
        HDLLink.getInstance().removeAllTopicsListener(allTopicsListener);
    }
    void initDeviceInfo()
    {
    void initDeviceInfo() {
        AuthenticateRequest.AuthenticateDeviceInfoBean infoBean = new AuthenticateRequest.AuthenticateDeviceInfoBean();
        infoBean.setDeviceMAC("AA000000000000AF");
        infoBean.setIPMAC("AA000000000000AF");
        infoBean.setDeviceMAC("AA00000000000100");
        infoBean.setIPMAC("AA00000000000100");
        infoBean.setDeviceName("音乐播放器");//设备名字
        infoBean.setDeviceModel("MCLog.431");//设备型号
        infoBean.setAccessMode("WIFI");
        infoBean.setIPGateway("192.168.1.1");
        infoBean.setIPAddress("192.168.1.102");
        infoBean.setIPAddress("192.168.1.116");
        infoBean.setGateway_type("music.standard");
        infoBean.setHw_version("HW2.0");
        infoBean.setFw_version("Fw1.0");
        infoBean.setOID("010105000000FE10");//每个设备oid都要不一样
        infoBean.setSid("110105000000FE08110100000000");//每个设备的sid都要不一样
        infoBean.setOID("010105000000FE11");//每个设备oid都要不一样
        infoBean.setSid("110105000000FE08110100000011");//每个设备的sid都要不一样
        HDLLinkConfig.getInstance().setDeviceInfoBean(infoBean);
    }
    /**
@@ -297,8 +283,8 @@
//        正式服务器
        String spkStr = "screen.mirror";//产品spk
        String macStr = "AA000000000000AC";//设备唯一MAC地址
        String secret = "ee62124c151b737c";//通过spk和mac提交云端认证后分配的secret
        String macStr = "AA00000000000100";//设备唯一MAC地址
        String secret = "e186beeb7974998e";//通过spk和mac提交云端认证后分配的secret
        String mac_key = stringToMD5(stringToMD5(macStr + secret));
        String versionString = "HDL_V1.0.1";//
@@ -320,15 +306,16 @@
        HDLLink.getInstance().startAuthenticateRequest(request, new HDLLinkCallBack() {
            @Override
            public void onError(HDLLinkException e) {
                tv.setText("认证失败");
                responseTv.setText(e.getMsg());
                Log.i("TAG", "onError: 认证失败");
//                tv.setText("认证失败");
//                responseTv.setText(e.getMsg());
                Log.i("TAG", "onError: 认证失败" + e.getMsg());
            }
            @Override
            public void onSuccess(String msg) {
                tv.setText("认证成功");
                responseTv.setText(msg.toString());
//                tv.setText("认证成功");
//                responseTv.setText(msg.toString());
                Log.i("TAG", "onSuccess: 认证成功" + msg.toString());
            }
        });
    }
@@ -364,15 +351,16 @@
        HDLLink.getInstance().searchGatewayBroadcast(new HDLAuthSocket.SearchGatewayCallBack() {
            @Override
            public void onError(HDLLinkException e) {
                tv.setText("网关不在线");
                responseTv.setText(e.getMsg());
//                tv.setText("网关不在线");
//                responseTv.setText(e.getMsg());
                Log.i("TAG", "网关不在线" + e.getMsg());
            }
            @Override
            public void onSuccess(GatewaySearchBean gatewaySearchBean) {
                tv.setText("网关在线");
                responseTv.setText("搜索成功 网关id:" + gatewaySearchBean.getGatewayId());
//                                LogUtils.i("TAG", "onSuccess: 搜索成功:"+gatewaySearchBean.getGatewayId());
//                tv.setText("网关在线");
//                responseTv.setText("搜索成功 网关id:" + gatewaySearchBean.getGatewayId());
                Log.i("TAG", "onSuccess: 搜索成功:"+gatewaySearchBean.getGatewayId());
            }
        });
    }
@@ -386,13 +374,15 @@
        HDLLink.getInstance().getFunctionList(new HDLLinkCallBack() {
            @Override
            public void onError(HDLLinkException error) {
                tv.setText(error.getMsg());
//                tv.setText(error.getMsg());
                Log.i("TAG", "onError 获取功能列表失败" + error.getMsg());
            }
            @Override
            public void onSuccess(String data) {
                tv.setText("获取功能列表成功");
                responseTv.setText(data);
//                tv.setText("获取功能列表成功");
//                responseTv.setText(data);
                Log.i("TAG", "onSuccess 获取功能列表成功" + data.toString());
            }
        });
    }
@@ -408,12 +398,14 @@
        HDLLink.getInstance().getFunctionAttribute(sids, new HDLLinkCallBack() {
            @Override
            public void onSuccess(String msg) {
                responseTv.setText(msg);
//                responseTv.setText(msg);
                Log.i("TAG", "onSuccess 功能属性读取成功" + msg.toString());
            }
            @Override
            public void onError(HDLLinkException e) {
                responseTv.setText(e.getMsg());
//                responseTv.setText(e.getMsg());
                Log.i("TAG", "onError 获取功能列表失败" + e.getMsg());
            }
        });
    }
@@ -429,20 +421,22 @@
        HDLLink.getInstance().propertyRead(list, new HDLLinkCallBack() {
            @Override
            public void onSuccess(String data) {
                tv.setText("读取成功");
                responseTv.setText(data);
//                tv.setText("读取成功");
//                responseTv.setText(data);
                Log.i("TAG", "onSuccess 读取设备状态成功" + data.toString());
            }
            @Override
            public void onError(HDLLinkException e) {
                tv.setText("读取失败");
                responseTv.setText(e.getMsg());
//                tv.setText("读取失败");
//                responseTv.setText(e.getMsg());
                Log.i("TAG", "onError 读取设备状态失败" + e.getMsg());
            }
        });
    }
    /**
     * 控制失败
     * 控制设备
     * 回复响应code为200 代表执行成功
     */
    void controlDecide() {
@@ -461,12 +455,14 @@
        HDLLink.getInstance().propertyDown(requestList, new HDLLinkCallBack() {
            @Override
            public void onSuccess(String data) {
                responseTv.setText(data);
//                responseTv.setText(data);
                Log.i("TAG", "onSuccess 控制设备成功" + data.toString());
            }
            @Override
            public void onError(HDLLinkException e) {
                responseTv.setText(e.getMsg());
//                responseTv.setText(e.getMsg());
                Log.i("TAG", "onError 控制设备失败" + e.getMsg());
            }
        });
    }
@@ -479,12 +475,14 @@
        HDLLink.getInstance().getSceneList(new HDLLinkCallBack() {
            @Override
            public void onSuccess(String msg) {
                responseTv.setText(msg);
//                responseTv.setText(msg);
                Log.i("TAG", "onSuccess 获取场景列表成功" + msg.toString());
            }
            @Override
            public void onError(HDLLinkException e) {
                responseTv.setText(e.getMsg());
//                responseTv.setText(e.getMsg());
                Log.i("TAG", "onError 获取场景列表失败" + e.getMsg());
            }
        });
    }
@@ -509,21 +507,23 @@
        HDLLink.getInstance().controlScene(sids, new HDLLinkCallBack() {
            @Override
            public void onSuccess(String msg) {
                responseTv.setText(msg);
//                responseTv.setText(msg);
                Log.i("TAG", "onSuccess 场景控制成功" + msg.toString());
            }
            @Override
            public void onError(HDLLinkException e) {
                responseTv.setText(e.getMsg());
//                responseTv.setText(e.getMsg());
                Log.i("TAG", "onError 场景控制失败" + e.getMsg());
            }
        });
    }
    void startDevicesListActivity() {
/*    void startDevicesListActivity() {
        Intent intent = new Intent(this, DevicesListActivity.class);
        startActivity(intent);
    }
    }*/
    /**
     * TCP发送 只发一次,不监听回复,不重发
@@ -577,13 +577,14 @@
        HDLLink.getInstance().udpSendMsg(propertyDownTopic, bodyStr, new HDLLinkResponseCallBack() {
            @Override
            public void onSuccess(LinkResponse msg) {
                Log.i("udpSendWithCallback", "udpSendWithCallback");
                responseTv.setText(GsonConvert.getGson().toJson(msg));
                Log.i("TAG", "onSuccess UDP发送成功" + GsonConvert.getGson().toJson(msg));
//                responseTv.setText(GsonConvert.getGson().toJson(msg));
            }
            @Override
            public void onError(HDLLinkException e) {
                responseTv.setText(e.getMsg());
//                responseTv.setText(e.getMsg());
                Log.i("TAG", "onError UDP发送失败" + e.getMsg());
            }
        });
    }
@@ -598,13 +599,14 @@
        HDLLink.getInstance().tcpSendMsg(propertyDownTopic, bodyStr, new HDLLinkCallBack() {
            @Override
            public void onSuccess(String msg) {
                Log.i("tcpSendWithCallback", "tcpSendWithCallback");
                responseTv.setText(msg);
                Log.i("TAG", "onSuccess TCP发送成功" + msg);
//                responseTv.setText(msg);
            }
            @Override
            public void onError(HDLLinkException e) {
                responseTv.setText(e.getMsg());
//                responseTv.setText(e.getMsg());
                Log.i("TAG", "onError TCP发送失败");
            }
        });
    }