Remarks
Mmc5603 | |
---|---|
Status | |
Source code | GitHub |
Datasheet(s) | GitHub |
NuGet package |
Code Example
private Mmc5603 sensor;
public override Task Initialize()
{
Resolver.Log.Info("Initialize...");
sensor = new Mmc5603(Device.CreateI2cBus());
// classical .NET events can be used
sensor.Updated += (sender, result) =>
{
Resolver.Log.Info($"Magnetic Field: [X:{result.New.X.MicroTesla:N2}," +
$"Y:{result.New.Y.MicroTesla:N2}," +
$"Z:{result.New.Z.MicroTesla:N2} (MicroTeslas)]");
};
// Example that uses an IObservable subscription to only be notified when the filter is satisfied
var consumer = Mmc5603.CreateObserver(
handler: result => Resolver.Log.Info($"Observer: [x] changed by threshold; new [x]: X:{result.New.X.MicroTesla:N2}, old: X:{result.Old?.X.MicroTesla:N2}"),
// only notify if there's a greater than 1 micro tesla on the Y axis
filter: result =>
{
if (result.Old is { } old)
{
return (result.New - old).Y > new MagneticField(1, MU.MicroTesla);
}
return false;
});
sensor.Subscribe(consumer);
return Task.CompletedTask;
}
public override async Task Run()
{
//Read from sensor
var result = await sensor.Read();
//output initial readings text to console
Resolver.Log.Info("Initial Readings:");
Resolver.Log.Info(
$"Magnetic field: [X:{result.X.MicroTesla:N2}," +
$"Y:{result.Y.MicroTesla:N2}," +
$"Z:{result.Z.MicroTesla:N2} (MicroTeslas)]");
sensor.StartUpdating(TimeSpan.FromMilliseconds(1500));
}
Sample project(s) available on GitHub
Syntax
public class Mmc5603 : ByteCommsSensorBase<MagneticField3D>, IObservable<IChangeResult<MagneticField3D>>, IDisposable, IMagnetometer, ISamplingSensor<MagneticField3D>, ISensor<MagneticField3D>, II2cPeripheral
Constructors
Mmc5603(II2cBus, byte)
Create a new Mmc5603 object using the default parameters for the component
Declaration
public Mmc5603(II2cBus i2cBus, byte address = 48)
Parameters
Type | Name | Description |
---|---|---|
II2cBus | i2cBus | I2C bus object - default = 400 KHz |
byte | address | Address of the Mmc5603 |
Remarks
Mmc5603 | |
---|---|
Status | |
Source code | GitHub |
Datasheet(s) | GitHub |
NuGet package |
Code Example
private Mmc5603 sensor;
public override Task Initialize()
{
Resolver.Log.Info("Initialize...");
sensor = new Mmc5603(Device.CreateI2cBus());
// classical .NET events can be used
sensor.Updated += (sender, result) =>
{
Resolver.Log.Info($"Magnetic Field: [X:{result.New.X.MicroTesla:N2}," +
$"Y:{result.New.Y.MicroTesla:N2}," +
$"Z:{result.New.Z.MicroTesla:N2} (MicroTeslas)]");
};
// Example that uses an IObservable subscription to only be notified when the filter is satisfied
var consumer = Mmc5603.CreateObserver(
handler: result => Resolver.Log.Info($"Observer: [x] changed by threshold; new [x]: X:{result.New.X.MicroTesla:N2}, old: X:{result.Old?.X.MicroTesla:N2}"),
// only notify if there's a greater than 1 micro tesla on the Y axis
filter: result =>
{
if (result.Old is { } old)
{
return (result.New - old).Y > new MagneticField(1, MU.MicroTesla);
}
return false;
});
sensor.Subscribe(consumer);
return Task.CompletedTask;
}
public override async Task Run()
{
//Read from sensor
var result = await sensor.Read();
//output initial readings text to console
Resolver.Log.Info("Initial Readings:");
Resolver.Log.Info(
$"Magnetic field: [X:{result.X.MicroTesla:N2}," +
$"Y:{result.Y.MicroTesla:N2}," +
$"Z:{result.Z.MicroTesla:N2} (MicroTeslas)]");
sensor.StartUpdating(TimeSpan.FromMilliseconds(1500));
}
Properties
ContinuousModeEnabled
Get/set continuous sensor reading mode
Declaration
public bool ContinuousModeEnabled { get; set; }
Property Value
Type | Description |
---|---|
bool |
Remarks
Mmc5603 | |
---|---|
Status | |
Source code | GitHub |
Datasheet(s) | GitHub |
NuGet package |
Code Example
private Mmc5603 sensor;
public override Task Initialize()
{
Resolver.Log.Info("Initialize...");
sensor = new Mmc5603(Device.CreateI2cBus());
// classical .NET events can be used
sensor.Updated += (sender, result) =>
{
Resolver.Log.Info($"Magnetic Field: [X:{result.New.X.MicroTesla:N2}," +
$"Y:{result.New.Y.MicroTesla:N2}," +
$"Z:{result.New.Z.MicroTesla:N2} (MicroTeslas)]");
};
// Example that uses an IObservable subscription to only be notified when the filter is satisfied
var consumer = Mmc5603.CreateObserver(
handler: result => Resolver.Log.Info($"Observer: [x] changed by threshold; new [x]: X:{result.New.X.MicroTesla:N2}, old: X:{result.Old?.X.MicroTesla:N2}"),
// only notify if there's a greater than 1 micro tesla on the Y axis
filter: result =>
{
if (result.Old is { } old)
{
return (result.New - old).Y > new MagneticField(1, MU.MicroTesla);
}
return false;
});
sensor.Subscribe(consumer);
return Task.CompletedTask;
}
public override async Task Run()
{
//Read from sensor
var result = await sensor.Read();
//output initial readings text to console
Resolver.Log.Info("Initial Readings:");
Resolver.Log.Info(
$"Magnetic field: [X:{result.X.MicroTesla:N2}," +
$"Y:{result.Y.MicroTesla:N2}," +
$"Z:{result.Z.MicroTesla:N2} (MicroTeslas)]");
sensor.StartUpdating(TimeSpan.FromMilliseconds(1500));
}
DefaultI2cAddress
The default I2C address for the peripheral
Declaration
public byte DefaultI2cAddress { get; }
Property Value
Type | Description |
---|---|
byte |
Remarks
Mmc5603 | |
---|---|
Status | |
Source code | GitHub |
Datasheet(s) | GitHub |
NuGet package |
Code Example
private Mmc5603 sensor;
public override Task Initialize()
{
Resolver.Log.Info("Initialize...");
sensor = new Mmc5603(Device.CreateI2cBus());
// classical .NET events can be used
sensor.Updated += (sender, result) =>
{
Resolver.Log.Info($"Magnetic Field: [X:{result.New.X.MicroTesla:N2}," +
$"Y:{result.New.Y.MicroTesla:N2}," +
$"Z:{result.New.Z.MicroTesla:N2} (MicroTeslas)]");
};
// Example that uses an IObservable subscription to only be notified when the filter is satisfied
var consumer = Mmc5603.CreateObserver(
handler: result => Resolver.Log.Info($"Observer: [x] changed by threshold; new [x]: X:{result.New.X.MicroTesla:N2}, old: X:{result.Old?.X.MicroTesla:N2}"),
// only notify if there's a greater than 1 micro tesla on the Y axis
filter: result =>
{
if (result.Old is { } old)
{
return (result.New - old).Y > new MagneticField(1, MU.MicroTesla);
}
return false;
});
sensor.Subscribe(consumer);
return Task.CompletedTask;
}
public override async Task Run()
{
//Read from sensor
var result = await sensor.Read();
//output initial readings text to console
Resolver.Log.Info("Initial Readings:");
Resolver.Log.Info(
$"Magnetic field: [X:{result.X.MicroTesla:N2}," +
$"Y:{result.Y.MicroTesla:N2}," +
$"Z:{result.Z.MicroTesla:N2} (MicroTeslas)]");
sensor.StartUpdating(TimeSpan.FromMilliseconds(1500));
}
MagneticField3D
The current magnetic field value
Declaration
public MagneticField3D? MagneticField3D { get; }
Property Value
Type | Description |
---|---|
MagneticField3D? |
Remarks
Mmc5603 | |
---|---|
Status | |
Source code | GitHub |
Datasheet(s) | GitHub |
NuGet package |
Code Example
private Mmc5603 sensor;
public override Task Initialize()
{
Resolver.Log.Info("Initialize...");
sensor = new Mmc5603(Device.CreateI2cBus());
// classical .NET events can be used
sensor.Updated += (sender, result) =>
{
Resolver.Log.Info($"Magnetic Field: [X:{result.New.X.MicroTesla:N2}," +
$"Y:{result.New.Y.MicroTesla:N2}," +
$"Z:{result.New.Z.MicroTesla:N2} (MicroTeslas)]");
};
// Example that uses an IObservable subscription to only be notified when the filter is satisfied
var consumer = Mmc5603.CreateObserver(
handler: result => Resolver.Log.Info($"Observer: [x] changed by threshold; new [x]: X:{result.New.X.MicroTesla:N2}, old: X:{result.Old?.X.MicroTesla:N2}"),
// only notify if there's a greater than 1 micro tesla on the Y axis
filter: result =>
{
if (result.Old is { } old)
{
return (result.New - old).Y > new MagneticField(1, MU.MicroTesla);
}
return false;
});
sensor.Subscribe(consumer);
return Task.CompletedTask;
}
public override async Task Run()
{
//Read from sensor
var result = await sensor.Read();
//output initial readings text to console
Resolver.Log.Info("Initial Readings:");
Resolver.Log.Info(
$"Magnetic field: [X:{result.X.MicroTesla:N2}," +
$"Y:{result.Y.MicroTesla:N2}," +
$"Z:{result.Z.MicroTesla:N2} (MicroTeslas)]");
sensor.StartUpdating(TimeSpan.FromMilliseconds(1500));
}
Methods
RaiseEventsAndNotify(IChangeResult<MagneticField3D>)
Raise events for subscribers and notify of value changes
Declaration
protected override void RaiseEventsAndNotify(IChangeResult<MagneticField3D> changeResult)
Parameters
Type | Name | Description |
---|---|---|
IChangeResult<MagneticField3D> | changeResult | The updated sensor data |
Overrides
Meadow.Foundation.SamplingSensorBase<Meadow.Units.MagneticField3D>.RaiseEventsAndNotify(Meadow.IChangeResult<Meadow.Units.MagneticField3D>)
Remarks
Mmc5603 | |
---|---|
Status | |
Source code | GitHub |
Datasheet(s) | GitHub |
NuGet package |
Code Example
private Mmc5603 sensor;
public override Task Initialize()
{
Resolver.Log.Info("Initialize...");
sensor = new Mmc5603(Device.CreateI2cBus());
// classical .NET events can be used
sensor.Updated += (sender, result) =>
{
Resolver.Log.Info($"Magnetic Field: [X:{result.New.X.MicroTesla:N2}," +
$"Y:{result.New.Y.MicroTesla:N2}," +
$"Z:{result.New.Z.MicroTesla:N2} (MicroTeslas)]");
};
// Example that uses an IObservable subscription to only be notified when the filter is satisfied
var consumer = Mmc5603.CreateObserver(
handler: result => Resolver.Log.Info($"Observer: [x] changed by threshold; new [x]: X:{result.New.X.MicroTesla:N2}, old: X:{result.Old?.X.MicroTesla:N2}"),
// only notify if there's a greater than 1 micro tesla on the Y axis
filter: result =>
{
if (result.Old is { } old)
{
return (result.New - old).Y > new MagneticField(1, MU.MicroTesla);
}
return false;
});
sensor.Subscribe(consumer);
return Task.CompletedTask;
}
public override async Task Run()
{
//Read from sensor
var result = await sensor.Read();
//output initial readings text to console
Resolver.Log.Info("Initial Readings:");
Resolver.Log.Info(
$"Magnetic field: [X:{result.X.MicroTesla:N2}," +
$"Y:{result.Y.MicroTesla:N2}," +
$"Z:{result.Z.MicroTesla:N2} (MicroTeslas)]");
sensor.StartUpdating(TimeSpan.FromMilliseconds(1500));
}
ReadSensor()
Reads data from the sensor
Declaration
protected override Task<MagneticField3D> ReadSensor()
Returns
Type | Description |
---|---|
Task<MagneticField3D> | The latest sensor reading |
Overrides
Meadow.Foundation.SamplingSensorBase<Meadow.Units.MagneticField3D>.ReadSensor()
Remarks
Mmc5603 | |
---|---|
Status | |
Source code | GitHub |
Datasheet(s) | GitHub |
NuGet package |
Code Example
private Mmc5603 sensor;
public override Task Initialize()
{
Resolver.Log.Info("Initialize...");
sensor = new Mmc5603(Device.CreateI2cBus());
// classical .NET events can be used
sensor.Updated += (sender, result) =>
{
Resolver.Log.Info($"Magnetic Field: [X:{result.New.X.MicroTesla:N2}," +
$"Y:{result.New.Y.MicroTesla:N2}," +
$"Z:{result.New.Z.MicroTesla:N2} (MicroTeslas)]");
};
// Example that uses an IObservable subscription to only be notified when the filter is satisfied
var consumer = Mmc5603.CreateObserver(
handler: result => Resolver.Log.Info($"Observer: [x] changed by threshold; new [x]: X:{result.New.X.MicroTesla:N2}, old: X:{result.Old?.X.MicroTesla:N2}"),
// only notify if there's a greater than 1 micro tesla on the Y axis
filter: result =>
{
if (result.Old is { } old)
{
return (result.New - old).Y > new MagneticField(1, MU.MicroTesla);
}
return false;
});
sensor.Subscribe(consumer);
return Task.CompletedTask;
}
public override async Task Run()
{
//Read from sensor
var result = await sensor.Read();
//output initial readings text to console
Resolver.Log.Info("Initial Readings:");
Resolver.Log.Info(
$"Magnetic field: [X:{result.X.MicroTesla:N2}," +
$"Y:{result.Y.MicroTesla:N2}," +
$"Z:{result.Z.MicroTesla:N2} (MicroTeslas)]");
sensor.StartUpdating(TimeSpan.FromMilliseconds(1500));
}
ReadTemperature()
Read the sensor temperature Doesn't work in continuous mode
Declaration
public Task<Temperature> ReadTemperature()
Returns
Type | Description |
---|---|
Task<Temperature> |
Remarks
Mmc5603 | |
---|---|
Status | |
Source code | GitHub |
Datasheet(s) | GitHub |
NuGet package |
Code Example
private Mmc5603 sensor;
public override Task Initialize()
{
Resolver.Log.Info("Initialize...");
sensor = new Mmc5603(Device.CreateI2cBus());
// classical .NET events can be used
sensor.Updated += (sender, result) =>
{
Resolver.Log.Info($"Magnetic Field: [X:{result.New.X.MicroTesla:N2}," +
$"Y:{result.New.Y.MicroTesla:N2}," +
$"Z:{result.New.Z.MicroTesla:N2} (MicroTeslas)]");
};
// Example that uses an IObservable subscription to only be notified when the filter is satisfied
var consumer = Mmc5603.CreateObserver(
handler: result => Resolver.Log.Info($"Observer: [x] changed by threshold; new [x]: X:{result.New.X.MicroTesla:N2}, old: X:{result.Old?.X.MicroTesla:N2}"),
// only notify if there's a greater than 1 micro tesla on the Y axis
filter: result =>
{
if (result.Old is { } old)
{
return (result.New - old).Y > new MagneticField(1, MU.MicroTesla);
}
return false;
});
sensor.Subscribe(consumer);
return Task.CompletedTask;
}
public override async Task Run()
{
//Read from sensor
var result = await sensor.Read();
//output initial readings text to console
Resolver.Log.Info("Initial Readings:");
Resolver.Log.Info(
$"Magnetic field: [X:{result.X.MicroTesla:N2}," +
$"Y:{result.Y.MicroTesla:N2}," +
$"Z:{result.Z.MicroTesla:N2} (MicroTeslas)]");
sensor.StartUpdating(TimeSpan.FromMilliseconds(1500));
}
Reset()
Reset the sensor
Declaration
public void Reset()
Remarks
Mmc5603 | |
---|---|
Status | |
Source code | GitHub |
Datasheet(s) | GitHub |
NuGet package |
Code Example
private Mmc5603 sensor;
public override Task Initialize()
{
Resolver.Log.Info("Initialize...");
sensor = new Mmc5603(Device.CreateI2cBus());
// classical .NET events can be used
sensor.Updated += (sender, result) =>
{
Resolver.Log.Info($"Magnetic Field: [X:{result.New.X.MicroTesla:N2}," +
$"Y:{result.New.Y.MicroTesla:N2}," +
$"Z:{result.New.Z.MicroTesla:N2} (MicroTeslas)]");
};
// Example that uses an IObservable subscription to only be notified when the filter is satisfied
var consumer = Mmc5603.CreateObserver(
handler: result => Resolver.Log.Info($"Observer: [x] changed by threshold; new [x]: X:{result.New.X.MicroTesla:N2}, old: X:{result.Old?.X.MicroTesla:N2}"),
// only notify if there's a greater than 1 micro tesla on the Y axis
filter: result =>
{
if (result.Old is { } old)
{
return (result.New - old).Y > new MagneticField(1, MU.MicroTesla);
}
return false;
});
sensor.Subscribe(consumer);
return Task.CompletedTask;
}
public override async Task Run()
{
//Read from sensor
var result = await sensor.Read();
//output initial readings text to console
Resolver.Log.Info("Initial Readings:");
Resolver.Log.Info(
$"Magnetic field: [X:{result.X.MicroTesla:N2}," +
$"Y:{result.Y.MicroTesla:N2}," +
$"Z:{result.Z.MicroTesla:N2} (MicroTeslas)]");
sensor.StartUpdating(TimeSpan.FromMilliseconds(1500));
}
Events
MagneticField3DUpdated
Raised when the magnetic field value changes
Declaration
public event EventHandler<IChangeResult<MagneticField3D>> MagneticField3DUpdated
Event Type
Type | Description |
---|---|
EventHandler<IChangeResult<MagneticField3D>> |
Remarks
Mmc5603 | |
---|---|
Status | |
Source code | GitHub |
Datasheet(s) | GitHub |
NuGet package |
Code Example
private Mmc5603 sensor;
public override Task Initialize()
{
Resolver.Log.Info("Initialize...");
sensor = new Mmc5603(Device.CreateI2cBus());
// classical .NET events can be used
sensor.Updated += (sender, result) =>
{
Resolver.Log.Info($"Magnetic Field: [X:{result.New.X.MicroTesla:N2}," +
$"Y:{result.New.Y.MicroTesla:N2}," +
$"Z:{result.New.Z.MicroTesla:N2} (MicroTeslas)]");
};
// Example that uses an IObservable subscription to only be notified when the filter is satisfied
var consumer = Mmc5603.CreateObserver(
handler: result => Resolver.Log.Info($"Observer: [x] changed by threshold; new [x]: X:{result.New.X.MicroTesla:N2}, old: X:{result.Old?.X.MicroTesla:N2}"),
// only notify if there's a greater than 1 micro tesla on the Y axis
filter: result =>
{
if (result.Old is { } old)
{
return (result.New - old).Y > new MagneticField(1, MU.MicroTesla);
}
return false;
});
sensor.Subscribe(consumer);
return Task.CompletedTask;
}
public override async Task Run()
{
//Read from sensor
var result = await sensor.Read();
//output initial readings text to console
Resolver.Log.Info("Initial Readings:");
Resolver.Log.Info(
$"Magnetic field: [X:{result.X.MicroTesla:N2}," +
$"Y:{result.Y.MicroTesla:N2}," +
$"Z:{result.Z.MicroTesla:N2} (MicroTeslas)]");
sensor.StartUpdating(TimeSpan.FromMilliseconds(1500));
}