static void Main(string[] args) { LLRPClient reader; int i; #region ProcessCommandLine if (args.Length < 1) { usage(); return; } /* get the options. Skip the last one as its the hostname */ for (i = 0; i < args.Length - 1; i++) { if ((args[i] == "-p") && (i < (args.Length - 1))) { i++; m_password = System.Convert.ToUInt32(args[i]); } else if ((args[i] == "-n") && (i < (args.Length - 1))) { i++; m_newPassword = System.Convert.ToUInt32(args[i]); } else if (args[i] == "-t") { m_tid = ENUM_ImpinjSerializedTIDMode.Enabled; } else if (args[i] == "-s") { m_shortRange = ENUM_ImpinjQTAccessRange.Short_Range; } else if ((args[i] == "-v") && (i < (args.Length - 1))) { i++; m_Verbose = System.Convert.ToUInt32(args[i]); } else if ((args[i] == "-q") && (i < (args.Length - 1))) { i++; m_qtmode = System.Convert.ToUInt32(args[i]); } else { usage(); return; } } m_readerName = args[i]; Console.WriteLine( "Impinj C# LTK.NET RFID Application DocSample5 reader - " + m_readerName + "\n"); Console.WriteLine( " qtMode:" + m_qtmode.ToString() + " Verbose:" + m_Verbose.ToString() + " Range:" + m_shortRange.ToString() + " SerializeTID:" + m_tid.ToString() + " OldPassword:"******" NewPassword:"******"Initializing\n"); //Create an instance of LLRP reader client. reader = new LLRPClient(); //Impinj Best Practice! Always Install the Impinj extensions Impinj_Installer.Install(); } #endregion #region EventHandlers { Console.WriteLine("Adding Event Handlers\n"); reader.OnReaderEventNotification += new delegateReaderEventNotification(reader_OnReaderEventNotification); reader.OnRoAccessReportReceived += new delegateRoAccessReport(reader_OnRoAccessReportReceived); } #endregion #region Connecting { Console.WriteLine("Connecting To Reader\n"); ENUM_ConnectionAttemptStatusType status; //Open the reader connection. Timeout after 5 seconds bool ret = reader.Open(m_readerName, 5000, out status); //Ensure that the open succeeded and that the reader // returned the correct connection status result if (!ret || status != ENUM_ConnectionAttemptStatusType.Success) { Console.WriteLine("Failed to Connect to Reader \n"); return; } } #endregion #region EnableExtensions { Console.WriteLine("Enabling Impinj Extensions\n"); MSG_IMPINJ_ENABLE_EXTENSIONS imp_msg = new MSG_IMPINJ_ENABLE_EXTENSIONS(); MSG_ERROR_MESSAGE msg_err; imp_msg.MSG_ID = msgID++; // note :this doesn't need to bet set as the library will default //Send the custom message and wait for 8 seconds MSG_CUSTOM_MESSAGE cust_rsp = reader.CUSTOM_MESSAGE(imp_msg, out msg_err, 8000); MSG_IMPINJ_ENABLE_EXTENSIONS_RESPONSE msg_rsp = cust_rsp as MSG_IMPINJ_ENABLE_EXTENSIONS_RESPONSE; if (msg_rsp != null) { if (msg_rsp.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(msg_rsp.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("Enable Extensions Command Timed out\n"); reader.Close(); return; } } #endregion #region FactoryDefault { Console.WriteLine("Factory Default the Reader\n"); // factory default the reader MSG_SET_READER_CONFIG msg_cfg = new MSG_SET_READER_CONFIG(); MSG_ERROR_MESSAGE msg_err; msg_cfg.ResetToFactoryDefault = true; msg_cfg.MSG_ID = msgID++; //this doesn't need to bet set as the library will default //if SET_READER_CONFIG affects antennas it could take several seconds to return MSG_SET_READER_CONFIG_RESPONSE rsp_cfg = reader.SET_READER_CONFIG(msg_cfg, out msg_err, 12000); if (rsp_cfg != null) { if (rsp_cfg.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(rsp_cfg.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("SET_READER_CONFIG Command Timed out\n"); reader.Close(); return; } } #endregion #region getReaderCapabilities { Console.WriteLine("Getting Reader Capabilities\n"); MSG_GET_READER_CAPABILITIES cap = new MSG_GET_READER_CAPABILITIES(); cap.MSG_ID = msgID++; cap.RequestedData = ENUM_GetReaderCapabilitiesRequestedData.All; //Send the custom message and wait for 8 seconds MSG_ERROR_MESSAGE msg_err; MSG_GET_READER_CAPABILITIES_RESPONSE msg_rsp = reader.GET_READER_CAPABILITIES(cap, out msg_err, 8000); if (msg_rsp != null) { if (msg_rsp.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(msg_rsp.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("GET reader Capabilities Command Timed out\n"); reader.Close(); return; } // Get the reader model number since some features are not // available on Speedway revolution. PARAM_GeneralDeviceCapabilities dev_cap = msg_rsp.GeneralDeviceCapabilities; // Check to make sure the model number mathces and that this device // is an impinj reader (deviceManufacturerName == 25882) if ((dev_cap == null) || (dev_cap.DeviceManufacturerName != 25882)) { Console.WriteLine("Could not determine reader model number\n"); reader.Close(); return; } // Need to parse version number strings and compare to make sure // that the reader version is higher than 4.4. Version readerVersion = new Version(dev_cap.ReaderFirmwareVersion); Version minimumVersion = new Version("4.4.0.0"); if (readerVersion < minimumVersion) { Console.WriteLine("Must use Octane 4.4 or later\n"); reader.Close(); return; } } #endregion #region SetReaderConfig { Console.WriteLine("Adding SET_READER_CONFIG n"); // Communicate that message to the reader MSG_SET_READER_CONFIG msg = new MSG_SET_READER_CONFIG(); msg.MSG_ID = msgID++; msg.ResetToFactoryDefault = false; // turn off all reports msg.ROReportSpec = new PARAM_ROReportSpec(); msg.ROReportSpec.TagReportContentSelector = new PARAM_TagReportContentSelector(); msg.ROReportSpec.TagReportContentSelector.EnableAccessSpecID = false; msg.ROReportSpec.TagReportContentSelector.EnableAntennaID = false; msg.ROReportSpec.TagReportContentSelector.EnableChannelIndex = false; msg.ROReportSpec.TagReportContentSelector.EnableFirstSeenTimestamp = false; msg.ROReportSpec.TagReportContentSelector.EnableInventoryParameterSpecID = false; msg.ROReportSpec.TagReportContentSelector.EnableLastSeenTimestamp = false; msg.ROReportSpec.TagReportContentSelector.EnablePeakRSSI = false; msg.ROReportSpec.TagReportContentSelector.EnableROSpecID = false; msg.ROReportSpec.TagReportContentSelector.EnableSpecIndex = false; msg.ROReportSpec.TagReportContentSelector.EnableTagSeenCount = false; /* report all tags immediately */ msg.ROReportSpec.ROReportTrigger = ENUM_ROReportTriggerType.Upon_N_Tags_Or_End_Of_ROSpec; msg.ROReportSpec.N = 1; /* turn on serialized TID if we are asked to */ PARAM_ImpinjTagReportContentSelector impinjTagData = new PARAM_ImpinjTagReportContentSelector(); impinjTagData.ImpinjEnableGPSCoordinates = new PARAM_ImpinjEnableGPSCoordinates(); impinjTagData.ImpinjEnableGPSCoordinates.GPSCoordinatesMode = ENUM_ImpinjGPSCoordinatesMode.Disabled; impinjTagData.ImpinjEnablePeakRSSI = new PARAM_ImpinjEnablePeakRSSI(); impinjTagData.ImpinjEnablePeakRSSI.PeakRSSIMode = ENUM_ImpinjPeakRSSIMode.Disabled; impinjTagData.ImpinjEnableRFPhaseAngle = new PARAM_ImpinjEnableRFPhaseAngle(); impinjTagData.ImpinjEnableRFPhaseAngle.RFPhaseAngleMode = ENUM_ImpinjRFPhaseAngleMode.Disabled; impinjTagData.ImpinjEnableSerializedTID = new PARAM_ImpinjEnableSerializedTID(); impinjTagData.ImpinjEnableSerializedTID.SerializedTIDMode = m_tid; msg.ROReportSpec.Custom.Add(impinjTagData); /* report access specs immediately as well */ msg.AccessReportSpec = new PARAM_AccessReportSpec(); msg.AccessReportSpec.AccessReportTrigger = ENUM_AccessReportTriggerType.End_Of_AccessSpec; // set the antenna configuration for all antennas msg.AntennaConfiguration = new PARAM_AntennaConfiguration[1]; msg.AntennaConfiguration[0] = new PARAM_AntennaConfiguration(); msg.AntennaConfiguration[0].AntennaID = 0; /* all antennas */ // use DRM autset mode PARAM_C1G2InventoryCommand c1g2Inv = new PARAM_C1G2InventoryCommand(); c1g2Inv.C1G2RFControl = new PARAM_C1G2RFControl(); c1g2Inv.C1G2RFControl.ModeIndex = 1000; c1g2Inv.C1G2RFControl.Tari = 0; // Use session 1 so we don't get too many reads c1g2Inv.C1G2SingulationControl = new PARAM_C1G2SingulationControl(); c1g2Inv.C1G2SingulationControl.Session = new TwoBits(1); c1g2Inv.C1G2SingulationControl.TagPopulation = 1; c1g2Inv.C1G2SingulationControl.TagTransitTime = 0; // add to the message msg.AntennaConfiguration[0].AirProtocolInventoryCommandSettings.Add(c1g2Inv); MSG_ERROR_MESSAGE msg_err; MSG_SET_READER_CONFIG_RESPONSE rsp = reader.SET_READER_CONFIG(msg, out msg_err, 12000); if (rsp != null) { if (rsp.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(rsp.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("SET_READER_CONFIG Command Timed out\n"); reader.Close(); return; } } #endregion #region ADDRoSpecWithXML { Console.WriteLine("Adding RoSpec from XML file \n"); Org.LLRP.LTK.LLRPV1.DataType.Message obj; ENUM_LLRP_MSG_TYPE msg_type; // read the XML from a file and validate its an ADD_ROSPEC try { string filename; filename = @"..\..\addRoSpec.xml"; FileStream fs = new FileStream(filename, FileMode.Open); StreamReader sr = new StreamReader(fs); string s = sr.ReadToEnd(); fs.Close(); LLRPXmlParser.ParseXMLToLLRPMessage(s, out obj, out msg_type); if (obj == null || msg_type != ENUM_LLRP_MSG_TYPE.ADD_ROSPEC) { Console.WriteLine("Could not extract message from XML"); reader.Close(); return; } } catch { Console.WriteLine("Unable to convert to valid XML"); reader.Close(); return; } MSG_ADD_ROSPEC msg = (MSG_ADD_ROSPEC)obj; msg.MSG_ID = msgID++; // Communicate that message to the reader MSG_ERROR_MESSAGE msg_err; MSG_ADD_ROSPEC_RESPONSE rsp = reader.ADD_ROSPEC(msg, out msg_err, 12000); if (rsp != null) { if (rsp.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(rsp.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("ADD_ROSPEC Command Timed out\n"); reader.Close(); return; } } #endregion #region ADDAccessSpec { /* This section adds a second accessSpec identical to the * first (except for its ID). This is duplicate code with * the goal of showing an example of how to build LLRP specs * from C# objects rather than XML */ Console.WriteLine("Adding AccessSpec from C# objects \n"); // create the target tag filter spec to perform access only on these tags // This only requires a single filter (LTK/LLRP supports up to 2 ) PARAM_C1G2TargetTag[] targetTag = new PARAM_C1G2TargetTag[1]; targetTag[0] = new PARAM_C1G2TargetTag(); targetTag[0].Match = true; targetTag[0].MB = new TwoBits(1); targetTag[0].Pointer = 16; targetTag[0].TagData = LLRPBitArray.FromHexString(""); targetTag[0].TagMask = LLRPBitArray.FromHexString(""); PARAM_C1G2TagSpec tagSpec = new PARAM_C1G2TagSpec(); tagSpec.C1G2TargetTag = targetTag; PARAM_AccessCommand accessCmd = new PARAM_AccessCommand(); accessCmd.AirProtocolTagSpec = new UNION_AirProtocolTagSpec(); accessCmd.AirProtocolTagSpec.Add(tagSpec); switch (m_qtmode) { case 0: PARAM_C1G2Read readStdTID = new PARAM_C1G2Read(); readStdTID.AccessPassword = 0; readStdTID.MB = new TwoBits(2); readStdTID.OpSpecID = 1; readStdTID.WordCount = 2; readStdTID.WordPointer = 0; accessCmd.AccessCommandOpSpec.Add(readStdTID); break; case 1: PARAM_C1G2Write writePassword = new PARAM_C1G2Write(); writePassword.OpSpecID = 2; writePassword.MB = new TwoBits(0); writePassword.AccessPassword = m_password; writePassword.WordPointer = 2; writePassword.WriteData = new UInt16Array(); writePassword.WriteData.Add((UInt16)((m_newPassword >> 16) & 0x0000ffff)); writePassword.WriteData.Add((UInt16)(m_newPassword & 0x0000ffff)); accessCmd.AccessCommandOpSpec.Add(writePassword); break; case 2: PARAM_C1G2Read readSerializedTID = new PARAM_C1G2Read(); readSerializedTID.AccessPassword = 0; readSerializedTID.MB = new TwoBits(2); readSerializedTID.OpSpecID = 3; readSerializedTID.WordCount = 6; readSerializedTID.WordPointer = 0; accessCmd.AccessCommandOpSpec.Add(readSerializedTID); PARAM_C1G2Read readPublicEPC = new PARAM_C1G2Read(); readPublicEPC.AccessPassword = 0; readPublicEPC.MB = new TwoBits(2); readPublicEPC.OpSpecID = 4; readPublicEPC.WordCount = 6; readPublicEPC.WordPointer = 6; accessCmd.AccessCommandOpSpec.Add(readPublicEPC); PARAM_C1G2Read readUser = new PARAM_C1G2Read(); readUser.AccessPassword = 0; readUser.MB = new TwoBits(3); readUser.OpSpecID = 5; readUser.WordCount = 32; readUser.WordPointer = 0; accessCmd.AccessCommandOpSpec.Add(readUser); break; case 3: PARAM_ImpinjGetQTConfig getQT = new PARAM_ImpinjGetQTConfig(); getQT.OpSpecID = 6; getQT.AccessPassword = m_password; accessCmd.AccessCommandOpSpec.Add(getQT); break; case 4: PARAM_ImpinjSetQTConfig setQTPrivate = new PARAM_ImpinjSetQTConfig(); setQTPrivate.OpSpecID = 7; setQTPrivate.AccessPassword = m_password; setQTPrivate.Persistence = ENUM_ImpinjQTPersistence.Permanent; setQTPrivate.DataProfile = ENUM_ImpinjQTDataProfile.Private; setQTPrivate.AccessRange = m_shortRange; accessCmd.AccessCommandOpSpec.Add(setQTPrivate); break; case 5: PARAM_ImpinjSetQTConfig setQTPublic = new PARAM_ImpinjSetQTConfig(); setQTPublic.OpSpecID = 8; setQTPublic.AccessPassword = m_password; setQTPublic.Persistence = ENUM_ImpinjQTPersistence.Permanent; setQTPublic.DataProfile = ENUM_ImpinjQTDataProfile.Public; setQTPublic.AccessRange = m_shortRange; accessCmd.AccessCommandOpSpec.Add(setQTPublic); break; case 6: PARAM_ImpinjSetQTConfig setQTPeek = new PARAM_ImpinjSetQTConfig(); setQTPeek.OpSpecID = 9; setQTPeek.AccessPassword = m_password; setQTPeek.Persistence = ENUM_ImpinjQTPersistence.Temporary; setQTPeek.DataProfile = ENUM_ImpinjQTDataProfile.Private; setQTPeek.AccessRange = ENUM_ImpinjQTAccessRange.Normal_Range; accessCmd.AccessCommandOpSpec.Add(setQTPeek); PARAM_C1G2Read readSerializedTIDPeek = new PARAM_C1G2Read(); readSerializedTIDPeek.AccessPassword = 0; readSerializedTIDPeek.MB = new TwoBits(2); readSerializedTIDPeek.OpSpecID = 10; readSerializedTIDPeek.WordCount = 6; readSerializedTIDPeek.WordPointer = 0; accessCmd.AccessCommandOpSpec.Add(readSerializedTIDPeek); PARAM_C1G2Read readPrivateEPC = new PARAM_C1G2Read(); readPrivateEPC.AccessPassword = 0; readPrivateEPC.MB = new TwoBits(1); readPrivateEPC.OpSpecID = 11; readPrivateEPC.WordCount = 8; readPrivateEPC.WordPointer = 2; accessCmd.AccessCommandOpSpec.Add(readPrivateEPC); PARAM_C1G2Read readUserPeek = new PARAM_C1G2Read(); readUserPeek.AccessPassword = 0; readUserPeek.MB = new TwoBits(3); readUserPeek.OpSpecID = 12; readUserPeek.WordCount = 32; readUserPeek.WordPointer = 0; accessCmd.AccessCommandOpSpec.Add(readUserPeek); break; case 7: PARAM_C1G2Write writeUser = new PARAM_C1G2Write(); writeUser.AccessPassword = m_password; writeUser.OpSpecID = 13; writeUser.WordPointer = 0; writeUser.MB = new TwoBits(3); writeUser.WriteData = new UInt16Array(); for (int x = 0; x < 32; x++) { writeUser.WriteData.Add((UInt16)m_random.Next(65536)); } accessCmd.AccessCommandOpSpec.Add(writeUser); break; case 8: PARAM_C1G2Write writePubEPC = new PARAM_C1G2Write(); writePubEPC.AccessPassword = m_password; writePubEPC.MB = new TwoBits(2); writePubEPC.OpSpecID = 14; writePubEPC.WordPointer = 6; writePubEPC.WriteData = new UInt16Array(); for (int x = 0; x < 6; x++) { writePubEPC.WriteData.Add((UInt16)m_random.Next(65536)); } accessCmd.AccessCommandOpSpec.Add(writePubEPC); break; case 9: PARAM_C1G2Read readRsvd = new PARAM_C1G2Read(); readRsvd.AccessPassword = m_password; readRsvd.MB = new TwoBits(0); readRsvd.OpSpecID = 15; readRsvd.WordCount = 4; readRsvd.WordPointer = 0; accessCmd.AccessCommandOpSpec.Add(readRsvd); break; } // create the stop trigger for the Access Spec PARAM_AccessSpecStopTrigger stop = new PARAM_AccessSpecStopTrigger(); stop.AccessSpecStopTrigger = ENUM_AccessSpecStopTriggerType.Null; stop.OperationCountValue = 0; // Create and set up the basic accessSpec PARAM_AccessSpec accessSpec = new PARAM_AccessSpec(); accessSpec.AccessSpecID = 24; accessSpec.AntennaID = 0; accessSpec.ROSpecID = 0; accessSpec.CurrentState = ENUM_AccessSpecState.Disabled; accessSpec.ProtocolID = ENUM_AirProtocols.EPCGlobalClass1Gen2; // add the access command and stop trigger to the accessSpec accessSpec.AccessCommand = accessCmd; accessSpec.AccessSpecStopTrigger = stop; // Add the Access Spec to the ADD_ACCESSSPEC message MSG_ADD_ACCESSSPEC addAccess = new MSG_ADD_ACCESSSPEC(); addAccess.MSG_ID = msgID++; addAccess.AccessSpec = accessSpec; // communicate the message to the reader MSG_ERROR_MESSAGE msg_err; MSG_ADD_ACCESSSPEC_RESPONSE rsp = reader.ADD_ACCESSSPEC(addAccess, out msg_err, 12000); if (rsp != null) { if (rsp.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(rsp.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("ADD_ACCESSSPEC Command Timed out\n"); reader.Close(); return; } } #endregion #region EnableAccessSpec { Console.WriteLine("Enabling AccessSpec\n"); MSG_ENABLE_ACCESSSPEC msg = new MSG_ENABLE_ACCESSSPEC(); msg.MSG_ID = msgID++; MSG_ERROR_MESSAGE msg_err; msg.AccessSpecID = 24; // this better match the ACCESSSPEC we created above MSG_ENABLE_ACCESSSPEC_RESPONSE rsp = reader.ENABLE_ACCESSSPEC(msg, out msg_err, 12000); if (rsp != null) { if (rsp.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(rsp.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("ENABLE_ACCESSSPEC Command Timed out\n"); reader.Close(); return; } } #endregion #region EnableRoSpec { Console.WriteLine("Enabling RoSpec\n"); MSG_ENABLE_ROSPEC msg = new MSG_ENABLE_ROSPEC(); msg.MSG_ID = msgID++; MSG_ERROR_MESSAGE msg_err; msg.ROSpecID = 1111; // this better match the ROSpec we created above MSG_ENABLE_ROSPEC_RESPONSE rsp = reader.ENABLE_ROSPEC(msg, out msg_err, 12000); if (rsp != null) { if (rsp.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(rsp.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("ENABLE_ROSPEC Command Timed out\n"); reader.Close(); return; } } #endregion #region StartRoSpec { Console.WriteLine("Starting RoSpec\n"); MSG_START_ROSPEC msg = new MSG_START_ROSPEC(); msg.MSG_ID = msgID++; MSG_ERROR_MESSAGE msg_err; msg.ROSpecID = 1111; // this better match the RoSpec we created above MSG_START_ROSPEC_RESPONSE rsp = reader.START_ROSPEC(msg, out msg_err, 12000); if (rsp != null) { if (rsp.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(rsp.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("START_ROSPEC Command Timed out\n"); reader.Close(); return; } } #endregion // this should be plenty long enough to do these commands Thread.Sleep(3000); #region StopRoSpec { Console.WriteLine("Stopping RoSpec\n"); MSG_STOP_ROSPEC msg = new MSG_STOP_ROSPEC(); MSG_ERROR_MESSAGE msg_err; msg.ROSpecID = 1111; // this better match the RoSpec we created above MSG_STOP_ROSPEC_RESPONSE rsp = reader.STOP_ROSPEC(msg, out msg_err, 12000); if (rsp != null) { if (rsp.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(rsp.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("STOP_ROSPEC Command Timed out\n"); reader.Close(); return; } } #endregion #region Clean Up Reader Configuration { Console.WriteLine("Factory Default the Reader\n"); // factory default the reader MSG_SET_READER_CONFIG msg_cfg = new MSG_SET_READER_CONFIG(); MSG_ERROR_MESSAGE msg_err; msg_cfg.ResetToFactoryDefault = true; msg_cfg.MSG_ID = msgID++;; // note this doesn't need to bet set as the library will default // Note that if SET_READER_CONFIG affects antennas it could take several seconds to return MSG_SET_READER_CONFIG_RESPONSE rsp_cfg = reader.SET_READER_CONFIG(msg_cfg, out msg_err, 12000); if (rsp_cfg != null) { if (rsp_cfg.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(rsp_cfg.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("SET_READER_CONFIG Command Timed out\n"); reader.Close(); return; } } #endregion Console.WriteLine(" Received " + opSpecCount + " OpSpec Results."); Console.WriteLine(" Received " + reportCount + " Tag Reports."); Console.WriteLine(" Received " + eventCount + " Events."); Console.WriteLine("Closing\n"); // clean up the reader reader.Close(); reader.OnReaderEventNotification -= new delegateReaderEventNotification(reader_OnReaderEventNotification); reader.OnRoAccessReportReceived -= new delegateRoAccessReport(reader_OnRoAccessReportReceived); }
public void ConfigReader() { #region EnableExtensions { Console.WriteLine("Enabling Impinj Extensions\n"); MSG_IMPINJ_ENABLE_EXTENSIONS imp_msg = new MSG_IMPINJ_ENABLE_EXTENSIONS(); MSG_ERROR_MESSAGE msg_err; imp_msg.MSG_ID = 1; // not this doesn't need to bet set as the library will default //Send the custom message and wait for 8 seconds MSG_CUSTOM_MESSAGE cust_rsp = reader.CUSTOM_MESSAGE(imp_msg, out msg_err, 8000); MSG_IMPINJ_ENABLE_EXTENSIONS_RESPONSE msg_rsp = cust_rsp as MSG_IMPINJ_ENABLE_EXTENSIONS_RESPONSE; if (msg_rsp != null) { if (msg_rsp.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(msg_rsp.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("Enable Extensions Command Timed out\n"); reader.Close(); return; } } #endregion #region FactoryDefault { Console.WriteLine("Factory Default the Reader\n"); // factory default the reader MSG_SET_READER_CONFIG msg_cfg = new MSG_SET_READER_CONFIG(); MSG_ERROR_MESSAGE msg_err; msg_cfg.ResetToFactoryDefault = true; msg_cfg.MSG_ID = 2; //this doesn't need to bet set as the library will default //if SET_READER_CONFIG affects antennas it could take several seconds to return MSG_SET_READER_CONFIG_RESPONSE rsp_cfg = reader.SET_READER_CONFIG(msg_cfg, out msg_err, 12000); if (rsp_cfg != null) { if (rsp_cfg.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(rsp_cfg.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("SET_READER_CONFIG Command Timed out\n"); reader.Close(); return; } } #endregion #region SetReaderConfig { Console.WriteLine("Adding SET_READER_CONFIG n"); // Communicate that message to the reader MSG_SET_READER_CONFIG msg = new MSG_SET_READER_CONFIG(); msg.ResetToFactoryDefault = false; // turn off all reports msg.ROReportSpec = new PARAM_ROReportSpec(); msg.ROReportSpec.TagReportContentSelector = new PARAM_TagReportContentSelector(); msg.ROReportSpec.TagReportContentSelector.EnableAccessSpecID = true; msg.ROReportSpec.TagReportContentSelector.EnableAntennaID = true; msg.ROReportSpec.TagReportContentSelector.EnableChannelIndex = true; msg.ROReportSpec.TagReportContentSelector.EnableFirstSeenTimestamp = true; msg.ROReportSpec.TagReportContentSelector.EnableInventoryParameterSpecID = true; msg.ROReportSpec.TagReportContentSelector.EnableLastSeenTimestamp = true; msg.ROReportSpec.TagReportContentSelector.EnablePeakRSSI = true; msg.ROReportSpec.TagReportContentSelector.EnableROSpecID = true; msg.ROReportSpec.TagReportContentSelector.EnableSpecIndex = true; msg.ROReportSpec.TagReportContentSelector.EnableTagSeenCount = true; // report all tags immediately msg.ROReportSpec.ROReportTrigger = ENUM_ROReportTriggerType.Upon_N_Tags_Or_End_Of_ROSpec; msg.ROReportSpec.N = 1; msg.ReaderEventNotificationSpec = new PARAM_ReaderEventNotificationSpec(); msg.ReaderEventNotificationSpec.EventNotificationState = new PARAM_EventNotificationState[1]; msg.ReaderEventNotificationSpec.EventNotificationState[0] = new PARAM_EventNotificationState(); msg.ReaderEventNotificationSpec.EventNotificationState[0].EventType = ENUM_NotificationEventType.ROSpec_Event; msg.ReaderEventNotificationSpec.EventNotificationState[0].NotificationState = true; PARAM_ImpinjTagReportContentSelector impinjTagData = new PARAM_ImpinjTagReportContentSelector(); impinjTagData.ImpinjEnableGPSCoordinates = new PARAM_ImpinjEnableGPSCoordinates(); impinjTagData.ImpinjEnableGPSCoordinates.GPSCoordinatesMode = ENUM_ImpinjGPSCoordinatesMode.Enabled; impinjTagData.ImpinjEnablePeakRSSI = new PARAM_ImpinjEnablePeakRSSI(); impinjTagData.ImpinjEnablePeakRSSI.PeakRSSIMode = ENUM_ImpinjPeakRSSIMode.Enabled; impinjTagData.ImpinjEnableRFPhaseAngle = new PARAM_ImpinjEnableRFPhaseAngle(); impinjTagData.ImpinjEnableRFPhaseAngle.RFPhaseAngleMode = ENUM_ImpinjRFPhaseAngleMode.Enabled; impinjTagData.ImpinjEnableRFDopplerFrequency = new PARAM_ImpinjEnableRFDopplerFrequency(); impinjTagData.ImpinjEnableRFDopplerFrequency.RFDopplerFrequencyMode = ENUM_ImpinjRFDopplerFrequencyMode.Enabled; msg.ROReportSpec.Custom.Add(impinjTagData); MSG_ERROR_MESSAGE msg_err; MSG_SET_READER_CONFIG_RESPONSE rsp = reader.SET_READER_CONFIG(msg, out msg_err, 12000); if (rsp != null) { if (rsp.LLRPStatus.StatusCode != ENUM_StatusCode.M_Success) { Console.WriteLine(rsp.LLRPStatus.StatusCode.ToString()); reader.Close(); return; } } else if (msg_err != null) { Console.WriteLine(msg_err.ToString()); reader.Close(); return; } else { Console.WriteLine("SET_READER_CONFIG Command Timed out\n"); reader.Close(); return; } } #endregion }
/// <summary>ROSpec 追加</summary> protected virtual void AddROSpec(uint roSpecId, bool isEnabledImpinjExtensions = false) { MSG_ADD_ROSPEC msg = new MSG_ADD_ROSPEC(); PARAM_ROSpec pROSpec = new PARAM_ROSpec(); msg.ROSpec = pROSpec; pROSpec.ROSpecID = roSpecId; pROSpec.Priority = 0; pROSpec.CurrentState = ENUM_ROSpecState.Disabled; // PARAM_ROBoundarySpec pBoundary = new PARAM_ROBoundarySpec(); pROSpec.ROBoundarySpec = pBoundary; // 開始トリガ pBoundary.ROSpecStartTrigger = new PARAM_ROSpecStartTrigger(); pBoundary.ROSpecStartTrigger.ROSpecStartTriggerType = ENUM_ROSpecStartTriggerType.Null; // 停止トリガ pBoundary.ROSpecStopTrigger = new PARAM_ROSpecStopTrigger(); pBoundary.ROSpecStopTrigger.ROSpecStopTriggerType = ENUM_ROSpecStopTriggerType.Null; pBoundary.ROSpecStopTrigger.DurationTriggerValue = 0; // レポートスペック PARAM_ROReportSpec pReport = new PARAM_ROReportSpec(); pROSpec.ROReportSpec = pReport; pReport.N = 1; pReport.ROReportTrigger = ENUM_ROReportTriggerType.Upon_N_Tags_Or_End_Of_ROSpec; PARAM_TagReportContentSelector pContentSelector = new PARAM_TagReportContentSelector(); pReport.TagReportContentSelector = pContentSelector; pContentSelector.EnableAntennaID = true; pContentSelector.EnablePeakRSSI = true; pContentSelector.EnableROSpecID = true; pContentSelector.EnableFirstSeenTimestamp = true; if (isEnabledImpinjExtensions) { var pImpinjContentSelector = new PARAM_ImpinjTagReportContentSelector(); pReport.Custom.Add(pImpinjContentSelector); pImpinjContentSelector.ImpinjEnablePeakRSSI = new PARAM_ImpinjEnablePeakRSSI() { PeakRSSIMode = ENUM_ImpinjPeakRSSIMode.Enabled }; pImpinjContentSelector.ImpinjEnableRFPhaseAngle = new PARAM_ImpinjEnableRFPhaseAngle() { RFPhaseAngleMode = ENUM_ImpinjRFPhaseAngleMode.Enabled }; } pROSpec.SpecParameter = new UNION_SpecParameter(); // AISpec PARAM_AISpec pAI = new PARAM_AISpec(); pROSpec.SpecParameter.Add(pAI); pAI.AntennaIDs = new UInt16Array(); pAI.AntennaIDs.Add(0); // AISpec Stop Trigger PARAM_AISpecStopTrigger pAISpecStopTrigger = new PARAM_AISpecStopTrigger(); pAI.AISpecStopTrigger = pAISpecStopTrigger; pAISpecStopTrigger.AISpecStopTriggerType = ENUM_AISpecStopTriggerType.Null; PARAM_InventoryParameterSpec pInventory = new PARAM_InventoryParameterSpec(); pAI.InventoryParameterSpec = new PARAM_InventoryParameterSpec[1]; pAI.InventoryParameterSpec[0] = pInventory; pInventory.InventoryParameterSpecID = 4567; pInventory.ProtocolID = ENUM_AirProtocols.EPCGlobalClass1Gen2; if (this.Settings != null) { pAI.AntennaIDs = new UInt16Array(); foreach (var ant in this.Settings.Antennas.Where(ant => ant.IsEnabled)) { pAI.AntennaIDs.Add(ant.Id); } pInventory.AntennaConfiguration = new PARAM_AntennaConfiguration[this.Settings.Antennas.Count]; for (ushort aid = 0; aid < this.Settings.Antennas.Count; ++aid) { PARAM_AntennaConfiguration pAntenna = new PARAM_AntennaConfiguration(); pInventory.AntennaConfiguration[aid] = pAntenna; var antenna = this.Settings.Antennas[aid]; pAntenna.AntennaID = antenna.Id; pAntenna.RFTransmitter = new PARAM_RFTransmitter(); pAntenna.RFTransmitter.ChannelIndex = 1; pAntenna.RFTransmitter.HopTableID = 0; pAntenna.RFTransmitter.TransmitPower = antenna.Tx.Id; pAntenna.RFReceiver = new PARAM_RFReceiver(); pAntenna.RFReceiver.ReceiverSensitivity = antenna.Rx.Id; pAntenna.AirProtocolInventoryCommandSettings = new UNION_AirProtocolInventoryCommandSettings(); var pInventoryCommand = new PARAM_C1G2InventoryCommand(); pAntenna.AirProtocolInventoryCommandSettings.Add(pInventoryCommand); pInventoryCommand.TagInventoryStateAware = false; pInventoryCommand.C1G2RFControl = new PARAM_C1G2RFControl(); pInventoryCommand.C1G2RFControl.ModeIndex = 1000; pInventoryCommand.C1G2RFControl.Tari = 0; pInventoryCommand.C1G2SingulationControl = new PARAM_C1G2SingulationControl(); pInventoryCommand.C1G2SingulationControl.Session = new TwoBits(false, false); pInventoryCommand.C1G2SingulationControl.TagPopulation = 32; pInventoryCommand.C1G2SingulationControl.TagTransitTime = 0; } } MSG_ERROR_MESSAGE? msgErr = null; MSG_ADD_ROSPEC_RESPONSE?msgResp = this.BaseClient?.ADD_ROSPEC( msg: msg, msg_err: out msgErr, time_out: 3000); this.CheckLLRPError(msgResp, msgErr); }