This application provides a set of demos with X-NUCLEO-NFC01A1 expansion board.
Dependencies: NDefLib X_NUCLEO_NFC01A1 mbed
Fork of X-MBED-NFC1 by
This application provides a set of demos with X-NUCLEO-NFC01A1 expansion board.
The available demos are:
- SAMPLE_WRITE_URL: write a tag with the ST home page URL
- SAMPLE_COUNT_CLICK: create a custom tag to count and report the user button clicks.
- SAMPLE_WRITE_AND_CHANGE_ALL: write a tag with all the supported records and update the tag contents when the user button is pressed.
- SAMPLE_LOCK_TAG_CONTENT: use the M24SR component API to set the NFC tag as read-only.
To enable the different demos comment/uncomment the SAMPLE_* macros provided in main.cpp .
Samples/SampleAsync_writeUrl.cpp
- Committer:
- giovannivisentini
- Date:
- 2016-08-31
- Revision:
- 14:3b604972b89f
- Parent:
- 13:685d95525ec8
- Child:
- 17:d8d3d2088cac
File content as of revision 14:3b604972b89f:
/**
******************************************************************************
* @file Sample_writeUrl.cpp
* @author ST / Central Labs
* @date 03 Dic 2015
* @brief This demo write an ndef message with an url inside
******************************************************************************
*
* COPYRIGHT(c) 2015 STMicroelectronics
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
* 3. Neither the name of STMicroelectronics nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
******************************************************************************
*/
#include "mbed.h"
#include "X_NUCLEO_NFC01A1.h"
#include "NDefLib/NDefNfcTag.h"
#include "NDefLib/RecordType/RecordURI.h"
/**
* Chain of callback that will crate a Uri record and write it.
* After each operation the class will switch on a led
*/
class WriteUriCallbacks : public NDefLib::NDefNfcTag::Callbacks{
DigitalOut &mOnOpenSession;
DigitalOut &mOnWrite;
DigitalOut &mOnCloseSession;
public:
/**
* create the callback chain
* @param onOpenSession led to switch on when the session open
* @param onWrite led to switch on when the write end
* @param onCloseSession led to switch on when the session end
*/
WriteUriCallbacks(DigitalOut &onOpenSession,DigitalOut &onWrite,
DigitalOut &onCloseSession):mOnOpenSession(onOpenSession),
mOnWrite(onWrite),mOnCloseSession(onCloseSession){};
/**
* crate the new message and write it
* @param tag tag where write the message
* @param success true if the session correctly open
*/
virtual void onSessionOpen(NDefLib::NDefNfcTag *tag,bool success){
if(!success){
printf("Error OpenSession\n\r");
}//else
printf("Session Open\n\r");
//ask to have an interrupt when the command finish
mOnOpenSession=1;
NDefLib::Message msg;
NDefLib::RecordURI rUri(NDefLib::RecordURI::HTTP_WWW,"http://www.st.com");
msg.addRecord(&rUri);
tag->write(msg);
}
/**
* request to close the session
* @param tag tag where close the session
* @param success true if the message is correctly wrote
* @param message wrote
*/
virtual void onMessageWrite(NDefLib::NDefNfcTag *tag,bool success,
const NDefLib::Message&){
if(!success)
printf("Error writing tag!\n\r");
else{
printf("Tag Wrote!\n\r");
mOnWrite=1;
}//if-else
tag->closeSession();
}
/**
* switch on the led
* @param tag where the session is closed
* @param success true if the session is correctly close
*/
virtual void onSessionClose(NDefLib::NDefNfcTag*,bool success){
if(success){
printf("Session closed\n\r");
mOnCloseSession=1;
}else
printf("Error Session closed\n\r");
}
};
/** variable set to true when we receive an interrupt from the nfc component*/
static volatile bool nfcInterruptFlag;
/** Nfc ISR called when the nfc component has a message ready*/
static void nfcInterruptCallback(){
nfcInterruptFlag=true;
}//nfcInterruptCallback
void sampleAsync_writeUrl(){
//create the nfc component
I2C i2cChannel(X_NUCLEO_NFC01A1::DEFAULT_SDA_PIN,X_NUCLEO_NFC01A1::DEFAULT_SDL_PIN);
X_NUCLEO_NFC01A1 *nfcNucleo = X_NUCLEO_NFC01A1::Instance(i2cChannel,&nfcInterruptCallback,
X_NUCLEO_NFC01A1::DEFAULT_GPO_PIN,X_NUCLEO_NFC01A1::DEFAULT_RF_DISABLE_PIN,
X_NUCLEO_NFC01A1::DEFAULT_LED1_PIN,X_NUCLEO_NFC01A1::DEFAULT_LED2_PIN,
X_NUCLEO_NFC01A1::DEFAULT_LED3_PIN);
//No call back needed since default behavior is sync
nfcNucleo->getM24SR().GetSession();
nfcNucleo->getM24SR().ManageI2CGPO(I2C_ANSWER_READY); //switch to async mode
NDefLib::NDefNfcTag &tag = nfcNucleo->getM24SR().getNDefTag();
printf("System Init done!\n\r");
//crate the callback to use for write a tag
WriteUriCallbacks NDefCallback(nfcNucleo->getLed1(),nfcNucleo->getLed2(),nfcNucleo->getLed3());
tag.setCallback(&NDefCallback); //set the callback
tag.openSession(); //start the callback chain
printf("Start Main Loop\n\r");
while(true){
if(nfcInterruptFlag){
nfcInterruptFlag=false;
//manage an async event from the nfc component
nfcNucleo->getM24SR().ManageEvent();
}//if
__WFE();
}//while
}
