Merge remote-tracking branch 'origin/dev_release' into dev_release
This commit is contained in:
commit
d3f1af9b8b
@ -31,14 +31,13 @@ namespace Assets.Scripts.Ble
|
|||||||
private Action<BleAdvertisementInfo> _discoveredCallback;
|
private Action<BleAdvertisementInfo> _discoveredCallback;
|
||||||
|
|
||||||
private Dictionary<BlePeripheralInfo, Action<IBleWinHwInterface, BlePeripheralInfo, BleResponse>> callbacks = new Dictionary<BlePeripheralInfo, Action<IBleWinHwInterface, BlePeripheralInfo, BleResponse>>();
|
private Dictionary<BlePeripheralInfo, Action<IBleWinHwInterface, BlePeripheralInfo, BleResponse>> callbacks = new Dictionary<BlePeripheralInfo, Action<IBleWinHwInterface, BlePeripheralInfo, BleResponse>>();
|
||||||
private Dictionary<string, Action> diconnectedCallbacks = new Dictionary<string, Action>();
|
|
||||||
private Dictionary<BlePeripheralInfo, Action<IBleWinHwInterface, BlePeripheralInfo, BleResponse<List<BleServiceInfo>>>> servicesCallbacks = new Dictionary<BlePeripheralInfo, Action<IBleWinHwInterface, BlePeripheralInfo, BleResponse<List<BleServiceInfo>>>>();
|
private Dictionary<BlePeripheralInfo, Action<IBleWinHwInterface, BlePeripheralInfo, BleResponse<List<BleServiceInfo>>>> servicesCallbacks = new Dictionary<BlePeripheralInfo, Action<IBleWinHwInterface, BlePeripheralInfo, BleResponse<List<BleServiceInfo>>>>();
|
||||||
//private Dictionary<BlePeripheralInfo, Action<BleWinHwInterface, BleServiceInfo, BleResponse<List<BleCharacteristicInfo>>>> characteristicsCallbacks = new Dictionary<BlePeripheralInfo, Action<BleWinHwInterface, BleServiceInfo, BleResponse<List<BleCharacteristicInfo>>>>();
|
//private Dictionary<BlePeripheralInfo, Action<BleWinHwInterface, BleServiceInfo, BleResponse<List<BleCharacteristicInfo>>>> characteristicsCallbacks = new Dictionary<BlePeripheralInfo, Action<BleWinHwInterface, BleServiceInfo, BleResponse<List<BleCharacteristicInfo>>>>();
|
||||||
private Dictionary<BlePeripheralInfo, Action<IBleWinHwInterface, BleCharacteristicInfo, BleResponse>> characteristicNotificationCallbacks = new Dictionary<BlePeripheralInfo, Action<IBleWinHwInterface, BleCharacteristicInfo, BleResponse>>();
|
private Dictionary<BlePeripheralInfo, Action<IBleWinHwInterface, BleCharacteristicInfo, BleResponse>> characteristicNotificationCallbacks = new Dictionary<BlePeripheralInfo, Action<IBleWinHwInterface, BleCharacteristicInfo, BleResponse>>();
|
||||||
private Dictionary<BleCharacteristicInfo, CharacteristicReadCallback> characteristicReadCallbacks = new Dictionary<BleCharacteristicInfo, CharacteristicReadCallback>();
|
private Dictionary<BleCharacteristicInfo, CharacteristicReadCallback> characteristicReadCallbacks = new Dictionary<BleCharacteristicInfo, CharacteristicReadCallback>();
|
||||||
private Dictionary<BleServiceInfo, CharacteristicsDiscoveredCallback> characteristicsDiscoveredCallbacks = new Dictionary<BleServiceInfo, CharacteristicsDiscoveredCallback>();
|
private Dictionary<BleServiceInfo, CharacteristicsDiscoveredCallback> characteristicsDiscoveredCallbacks = new Dictionary<BleServiceInfo, CharacteristicsDiscoveredCallback>();
|
||||||
|
|
||||||
private Dictionary<BlePeripheralInfo, Action> disconnectedCallback = new Dictionary<BlePeripheralInfo, Action>();
|
private Dictionary<string, Action> disconnectedCallback = new Dictionary<string, Action>();
|
||||||
|
|
||||||
private CharacteristicReadCallback characteristicReadEvent;
|
private CharacteristicReadCallback characteristicReadEvent;
|
||||||
public event CharacteristicReadCallback CharacteristicReadEvent
|
public event CharacteristicReadCallback CharacteristicReadEvent
|
||||||
@ -323,7 +322,7 @@ namespace Assets.Scripts.Ble
|
|||||||
this.callbacks.Remove(currentCallback.First().Key);
|
this.callbacks.Remove(currentCallback.First().Key);
|
||||||
}
|
}
|
||||||
|
|
||||||
var currentDisconnectCallback = this.disconnectedCallback.Where(c => c.Key.MatchAddress(address));
|
var currentDisconnectCallback = this.disconnectedCallback.Where(c => c.Key == address);
|
||||||
if (currentDisconnectCallback.Any())
|
if (currentDisconnectCallback.Any())
|
||||||
{
|
{
|
||||||
this.disconnectedCallback.Remove(currentDisconnectCallback.First().Key);
|
this.disconnectedCallback.Remove(currentDisconnectCallback.First().Key);
|
||||||
@ -352,7 +351,7 @@ namespace Assets.Scripts.Ble
|
|||||||
//设备断开连接
|
//设备断开连接
|
||||||
public void DisconnectPeripheral(BlePeripheralInfo peripheral, Action callback)
|
public void DisconnectPeripheral(BlePeripheralInfo peripheral, Action callback)
|
||||||
{
|
{
|
||||||
diconnectedCallbacks.Add(peripheral.Address,callback);
|
disconnectedCallback.Add(peripheral.Address,callback);
|
||||||
BluetoothLEHardwareInterface.DisconnectPeripheral(peripheral.Address, (address) =>
|
BluetoothLEHardwareInterface.DisconnectPeripheral(peripheral.Address, (address) =>
|
||||||
{
|
{
|
||||||
Debug.Log("断开回调" + address);
|
Debug.Log("断开回调" + address);
|
||||||
@ -360,7 +359,7 @@ namespace Assets.Scripts.Ble
|
|||||||
PeripheralDisconnected(address, ble);
|
PeripheralDisconnected(address, ble);
|
||||||
peripheralDisconnectedEvent(this, ble, null, true);
|
peripheralDisconnectedEvent(this, ble, null, true);
|
||||||
|
|
||||||
var currentCallback = diconnectedCallbacks.Where(c => c.Key.Equals(address)).Select(c=>c.Value).FirstOrDefault();
|
var currentCallback = disconnectedCallback.Where(c => c.Key.Equals(address)).Select(c=>c.Value).FirstOrDefault();
|
||||||
currentCallback?.Invoke();
|
currentCallback?.Invoke();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user