Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)

NodeMCU v1 ESP8266 보드의 A0 핀 사용법 - FSR-402 아날로그 압력 센서 연동

센서 값이 워낙 저가이다 보니, 한 번 주문할 때 배송비가 아까워 ^^; 뭔가를 하나 더 구매하게 되는데요, 지난번 조도 센서와 함께 구매한 압력 센서(FSR: Force Sender Resistor)를,

[Interlink] [정품] 압력센서 FSR-402
; www.devicemart.co.kr

[그림 출처: https://www.devicemart.co.kr/goods/view?no=33870]
fsr_sensor_1.png

사용해 보겠습니다. ^^

그런데, 사실 센서가 다르긴 하지만 압력 센서 역시 조도 센서와 마찬가지로 아날로그 값을 읽어들이므로 사용법이 동일합니다. 그래서 지난 글에서 소개한 회로에서 조도 센서의 자리에 압력 센서만 교체하면 잘 동작합니다.

fsr_sensor_2.png

마찬가지로 배선도 기존 회로에서 압력 센서로 교체하고,

fsr_sensor_3.png

테스트를 해보면, 압력이 전혀 없을 때 1024의 값이, 손으로 강하게 눌렀을 때 77 정도의 값이 A0 핀에서 읽혔습니다. 당연히 아두이노 코드도 구조가 동일하고 단지 값의 해석만 달리합니다.

int _fsrPin = A0;
int _builtInLed = 16;

void setup() {
  Serial.begin(115200);
  pinMode(_builtInLed, OUTPUT);
}

void loop() {

  int fsrValue = analogRead(_fsrPin);
  Serial.print("Force = ");
  Serial.println(fsrValue);

  int fsrPercentage = map(fsrValue, 0, 1023, 0, 100);
  if (fsrPercentage < 50)
  {
    digitalWrite(_builtInLed, HIGH); // 힘이 감지되면,
  }
  else
  {
    digitalWrite(_builtInLed, LOW); // 눌리지 않았으면,
  }
  delay(1000);
}

또한, 아래의 글에 있는 소스 코드를 덧입히면,

ThingSpeak 사물인터넷 플랫폼에 ESP8266 NodeMCU v1 + 조도 센서 장비 연동
; https://www.sysnet.pe.kr/2/0/12631

압력 센서의 값도 ThinkSpeak에 와이파이 통신을 이용해 전송할 수 있습니다.

#include "ThingSpeak.h"
#include "secrets.h"

unsigned long myChannelNumber = SECRET_CH_ID;
const char * myWriteAPIKey = SECRET_WRITE_APIKEY;

#include <ESP8266WiFi.h>

int _fsrPin = A0;

const char *ssid = SECRET_SSID;
const char *pass = SECRET_PASS;

WiFiClient  client;

void setup() {
  Serial.begin(115200);

  delay(1000);
  ThingSpeak.begin(client);    
}

void loop() {

  if (WiFi.status() != WL_CONNECTED)
  {
    WiFi.begin(ssid, pass);
    Serial.print(".");    
    delay(5000);
  }

  if (WiFi.status() != WL_CONNECTED)
  {
    return;
  }
  
  int fsrValue = analogRead(_fsrPin);
  ThingSpeak.setField(1, (float)fsrValue);

  int httpCode = ThingSpeak.writeFields(myChannelNumber, myWriteAPIKey);

  if (httpCode == 200) {
    Serial.println("Channel write successful.");
  }
  else {
    Serial.println("Problem writing to channel. HTTP error code " + String(httpCode));
  }
  
  delay(1000 * 20);
}

(첨부 파일은 FSR datasheet와 Fritzing 파일을 포함합니다.)




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 5/10/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  38  39  40  41  [42]  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12583정성태3/29/202111457개발 환경 구성: 561. kubectl 수행 시 다른 k8s 클러스터로 접속하는 방법
12582정성태3/29/202110146오류 유형: 709. Visual C++ - 컴파일 에러 error C2059: syntax error: '__stdcall'
12581정성태3/28/202110063.NET Framework: 1031. WinForm/WPF에서 Console 창을 띄워 출력하는 방법 (2) - Output 디버깅 출력을 AllocConsole로 우회 [2]
12580정성태3/28/20218813오류 유형: 708. SQL Server Management Studio - Execution Timeout Expired.
12579정성태3/28/20218917오류 유형: 707. 중첩 가상화(Nested Virtualization) - The virtual machine could not be started because this platform does not support nested virtualization.
12578정성태3/27/20219178개발 환경 구성: 560. Docker Desktop for Windows 기반의 Kubernetes 구성 (2) - WSL 2 인스턴스에 kind가 구성한 k8s 서비스 위치
12577정성태3/26/202111225개발 환경 구성: 559. Docker Desktop for Windows 기반의 Kubernetes 구성 - WSL 2 인스턴스에 kind 도구로 k8s 클러스터 구성
12576정성태3/25/20218987개발 환경 구성: 558. Docker Desktop for Windows에서 DockerDesktopVM 기반의 Kubernetes 구성 (2) - k8s 서비스 위치
12575정성태3/24/20218098개발 환경 구성: 557. Docker Desktop for Windows에서 DockerDesktopVM 기반의 Kubernetes 구성
12574정성태3/23/202112122.NET Framework: 1030. C# Socket의 Close/Shutdown 동작 (동기 모드)
12573정성태3/22/20219940개발 환경 구성: 556. WSL 인스턴스 초기 설정 명령어 [1]
12572정성태3/22/20219490.NET Framework: 1029. C# - GC 호출로 인한 메모리 압축(Compaction)을 확인하는 방법파일 다운로드1
12571정성태3/21/20218624오류 유형: 706. WSL 2 기반으로 "Enable Kubernetes" 활성화 시 초기화 실패 [1]
12570정성태3/19/202112930개발 환경 구성: 555. openssl - CA로부터 인증받은 새로운 인증서를 생성하는 방법
12569정성태3/18/202111806개발 환경 구성: 554. WSL 인스턴스 export/import 방법 및 단축 아이콘 설정 방법
12568정성태3/18/20217399오류 유형: 705. C# 빌드 - Couldn't process file ... due to its being in the Internet or Restricted zone or having the mark of the web on the file.
12567정성태3/17/20218794개발 환경 구성: 553. Docker Desktop for Windows를 위한 k8s 대시보드 활성화 [1]
12566정성태3/17/20219129개발 환경 구성: 552. Kubernetes - kube-apiserver와 REST API 통신하는 방법 (Docker Desktop for Windows 환경)
12565정성태3/17/20216623오류 유형: 704. curl.exe 실행 시 dll not found 오류
12564정성태3/16/20217103VS.NET IDE: 160. 새 프로젝트 창에 C++/CLI 프로젝트 템플릿이 없는 경우
12563정성태3/16/20219084개발 환경 구성: 551. C# - JIRA REST API 사용 정리 (3) jira-oauth-cli 도구를 이용한 키 관리
12562정성태3/15/202110194개발 환경 구성: 550. C# - JIRA REST API 사용 정리 (2) JIRA OAuth 토큰으로 API 사용하는 방법파일 다운로드1
12561정성태3/12/20218799VS.NET IDE: 159. Visual Studio에서 개행(\n, \r) 등의 제어 문자를 치환하는 방법 - 정규 표현식 사용
12560정성태3/11/202110131개발 환경 구성: 549. ssh-keygen으로 생성한 개인키/공개키 파일을 각각 PKCS8/PEM 형식으로 변환하는 방법
12559정성태3/11/20219573.NET Framework: 1028. 닷넷 5 환경의 Web API에 OpenAPI 적용을 위한 NSwag 또는 Swashbuckle 패키지 사용 [2]파일 다운로드1
12558정성태3/10/20219022Windows: 192. Power Automate Desktop (Preview) 소개 - Bitvise SSH Client 제어 [1]
... 31  32  33  34  35  36  37  38  39  40  41  [42]  43  44  45  ...