목표

CANoe에서 사용 가능한 UI에 대해서 시간을 들여서 좀 더 상세히 확인

제작

1. System Variable제작

2. Input/Output Box를 드래그해서 제작 후, Property설정 후 System Variable 연결

3. 코드 제작 후 실행 확인

/*@!Encoding:65001*/

on start {
  // Initialize the CAN address when the program starts
  AdjustCANAddress();  
}

on sysvar sysvar::Engine::_btnTransmit {
  // Buffer to store the CAN address (maximum 8 characters + null terminator)
  char canAddress[9];  
  
  // Check if the button is pressed
  if(@this == 1) {
    // Retrieve the current CAN address
    GetCANAddress(canAddress);
    // Print the CAN address when the button is clicked
    write(":: Current CAN Address: %s", canAddress);
  }
}

// This event triggers when the CAN address input field changes
on sysvar sysvar::Engine::_txtCANAddress {
  // Adjust the CAN address whenever it is modified
  AdjustCANAddress();  
}

// Function to adjust the CAN address
void AdjustCANAddress() {
  // Buffer to hold the input CAN address (temporary storage)
  char buffer[128];  
  // Buffer to store a valid CAN address (max 8 characters + null terminator)
  char limit[9];  
  
  // Retrieve the current CAN address value from the system variable
  sysGetVariableString(sysvar::Engine::_txtCANAddress, buffer, elcount(buffer));
  
  // If the input field is empty, set a default CAN address
  if(strlen(buffer) <= 0) {
    sysSetVariableString(sysvar::Engine::_txtCANAddress, "18DA01F1");
  } 
  // If the input exceeds 8 characters, truncate it to 8 characters
  else if(strlen(buffer) > 8) {
    // Copy only the first 8 characters
    mbstrncpy(limit, buffer, 8);
    // Update the system variable with the trimmed address
    sysSetVariableString(sysvar::Engine::_txtCANAddress, limit);  
  }
}

// Function to retrieve the adjusted CAN address
void GetCANAddress(char buffer[]) {
  AdjustCANAddress();  // Ensure the CAN address is properly formatted
  
  // Retrieve the adjusted CAN address from the system variable
  sysGetVariableString(sysvar::Engine::_txtCANAddress, buffer, elcount(buffer));
  
  // Ensure the string is properly null-terminated
  buffer[strlen(buffer)] = '\\0';
}

'Programming > CANoe' 카테고리의 다른 글

CANoe UI 만들기: 버튼  (0) 2025.03.10
CANoe 함수: mbstrncpy  (0) 2025.03.10
CANoe 함수: strlen  (0) 2025.03.10
CANoe 함수: sysSetVariableString  (0) 2025.03.10
CANoe 함수: sysGetVariableString  (0) 2025.03.02
블로그 이미지

RIsN

,

목표

CANoe에서 사용 가능한 UI에 대해서 시간을 들여서 좀 더 상세히 확인

제작

1. Environment → System Variables → System Variables Configuration으로 이동

2. 오른쪽 클릭으로 New 선택

3. 수치 설정 후 OK

  • 초기값 (Initial Value)또한, 글로벌 설정에서 특정 옵션을 활성화한 경우, 측정이 시작될 때마다 시스템 변수는 이 초기값으로 리셋됩니다.
    1. 데이터 (Data 타입)
      • 값을 두 자리 16진수(HEX) 숫자로 입력하며, 값 사이를 공백(space) 으로 구분합니다.
      • 예시: 01 2A FF → 3바이트 데이터 (01, 2A, FF)
    2. 정수 배열 (Integer Array 타입)
      • 배열 요소를 Int32(32비트 정수) 값으로 입력하며, 값 사이를 세미콜론(;) 으로 구분합니다.
      • 예시: 5;8;33 → 크기가 3인 배열 ([5, 8, 33])
    3. 기타 데이터 타입 (Other Data Types)
      • 해당 데이터 타입의 값 범위 내에서 적절한 값을 입력해야 합니다.
  • 초기값을 지정하는 방법은 시스템 변수의 데이터 타입에 따라 다릅니다:
  • 초기값을 지정하면, 시스템 변수가 처음 정의될 때 해당 값으로 설정됩니다.
  • 값 할당 시 이벤트 (Events on Value Assignment)설정 가능한 이벤트 생성 방식은 다음과 같습니다:
    1. 마지막 값으로 한 번만 이벤트 발생 (One Event with Last Value)
      • 여러 값이 한 번에 할당되더라도, 가장 마지막에 할당된 값으로 단 한 번의 이벤트만 생성됩니다.
    2. 모든 값에 대해 이벤트 발생 (All Events)
      • 할당된 각각의 값에 대해 이벤트가 개별적으로 생성됩니다.
      • 이 경우, 모든 이벤트는 같은 타임스탬프(time stamp) 를 갖게 됩니다.
  • 시스템 변수의 값이 변경될 때 이벤트가 트리거되는데, 특정 옵션을 통해 여러 값이 동시에 할당될 경우 이벤트 생성 방식을 설정할 수 있습니다.

4. Panel에서 Button을 Drag로 생성

5. Property를 수정

6. Symbol Values의 Value 선택

7. 제작한 System Variable을 선택 후 OK

8. 버튼용 함수를 제작

// :: Transmit Button
on sysvar sysvar::Engine::_btnTransmit {
  // :: Click
  if(@this == 1) {
    write(":: Button Clicked");
  }
}

9. 실행 확인

 

'Programming > CANoe' 카테고리의 다른 글

CANoe UI 만들기: 텍스트 박스  (0) 2025.03.10
CANoe 함수: mbstrncpy  (0) 2025.03.10
CANoe 함수: strlen  (0) 2025.03.10
CANoe 함수: sysSetVariableString  (0) 2025.03.10
CANoe 함수: sysGetVariableString  (0) 2025.03.02
블로그 이미지

RIsN

,

목표

함수 정리 및 개인적인 시간이 있을 때 설명 읽어두기.

각 함수 설명

mbstrncpy

  • 멀티바이트 문자열(Multibyte String)에서 특정 길이만큼 문자를 복사하는 함수입니다.
  • 일반적인 strncpy(...) 함수와 다르게, 다국어(UTF-8, Shift-JIS 등) 환경에서도 정확한 문자 개수를 복사할 수 있도록 설계되었습니다.

사용법

void mbstrncpy(char dest[], char src[], long len);
  • dest → 복사할 대상 문자열 (버퍼)
  • src → 원본 문자열
  • len → 복사할 문자 개수 (-1을 입력하면 가능한 한 최대 길이를 복사)
  • 널 종료 문자(\0)는 자동으로 추가됨

예제

char source[50] = "Hello, World!";
char destination[20];

mbstrncpy(destination, source, 5);
write("Result: %s", destination);

➡️ "Hello"가 destination에 복사됨.

✅ 널 종료 문자(\0)는 자동으로 추가됨 (즉, strncpy(...)와 다르게 마지막 문자가 \0으로 보장됨).

✅ 다국어 문자열(일본어, 한글 등)에서 한 문자가 여러 바이트인 경우에도 정상 동작.

✅ len 매개변수를 -1로 설정하면 가능한 최대한의 문자열을 복사.

mbstrncpy_off

  • 문자열을 특정 위치(destOffset)에서부터 덮어쓰기(overwrite)하는 함수입니다.

사용법

void mbstrncpy_off(char dest[], long destOffset, char src[], long len);
  • dest → 변경할 대상 문자열
  • destOffset → 대상 문자열에서 복사를 시작할 위치 (문자 단위)
  • src → 원본 문자열
  • len → 복사할 문자 개수 (-1을 입력하면 가능한 최대한 복사)

예제

char s1[50] = "eine grüne "; // 독일어로 "a green"
char s2[10] = "Türen"; // 독일어로 "doors"

mbstrncpy_off(s1, 11, s2, 3);
write("Result: %s", s1);  // "eine grüne Tür"

비교

함수 기능 주요특징
mbstrncpy(dest, src, len) 멀티바이트 문자열 복사 다국어 지원, 최대 길이 설정 가능 (-1 사용 가능)
mbstrncpy_off(dest, offset, src, len) 특정 위치에서 문자열 덮어쓰기 지정된 오프셋에서 복사 가능
strncpy(dest, src, len) 일반 문자열 복사 다국어 지원 ❌, 바이트 단위로 동작

'Programming > CANoe' 카테고리의 다른 글

CANoe UI 만들기: 텍스트 박스  (0) 2025.03.10
CANoe UI 만들기: 버튼  (0) 2025.03.10
CANoe 함수: strlen  (0) 2025.03.10
CANoe 함수: sysSetVariableString  (0) 2025.03.10
CANoe 함수: sysGetVariableString  (0) 2025.03.02
블로그 이미지

RIsN

,