XUserRegisterForChangeEvent
사용자 변경 이벤트에 대한 콜백을 등록합니다.
구문
HRESULT XUserRegisterForChangeEvent(
XTaskQueueHandle queue,
void* context,
XUserChangeEventCallback* callback,
XTaskQueueRegistrationToken* token
)
매개 변수
queue _In_opt_
형식: XTaskQueueHandle
작업을 수행할 비동기 큐에 대한 핸들입니다.
context _In_opt_
형식: void*
콜백에 전달할 사용자 정의 컨텍스트입니다.
callback _In_
형식: XUserChangeEventCallback*
등록할 사용자 정의 콜백입니다.
token _Out_
형식: XTaskQueueRegistrationToken*
등록된 콜백 함수를 식별하는 토큰을 포함합니다. 토큰을 이용해 콜백을 등록 해제합니다.
반환 값
형식: HRESULT
HRESULT 성공 또는 오류 코드입니다.
오류 코드 목록은 오류 코드를 참조하세요.
설명
참고 항목
이 함수는 시간에 민감한 스레드에서 호출하는 것이 안전하지 않습니다. 자세한 내용은 시간에 민감한 스레드를 참조하세요.
XUserChangeEvent 열거형은 변경 이벤트 형식을 지정합니다. XUserChangeEventCallback은 사용자 변경 이벤트에 대 한 콜백입니다.
이전에 등록한 사용자 변경 콜백을 등록 해제하려면 XUserUnregisterForChangeEvent를 호출합니다.
다음 예제에서는 사용자 변경 이벤트를 처리하는 방법을 보여줍니다.
HRESULT RegisterForChanges()
{
RETURN_HR_IF(E_UNEXPECTED, _token.token != 0);
RETURN_IF_FAILED(XUserRegisterForChangeEvent(
_queue,
this,
UserChangeEventHandler,
&_token));
return S_OK;
}
void UnregisterForChanges()
{
XUserUnregisterForChangeEvent(_token, false);
_token.token = 0;
}
void UserChangeEventHandler(
XUserLocalId userLocalId,
XUserChangeEvent event)
{
auto iter = std::find_if(
_users.begin(),
_users.end(),
[&userLocalId](const User& candidate)
{
XUserLocalId candidateUserLocalId;
XUserGetLocalId(candidate.Handle(), &candidateUserLocalId);
return candidateUserLocalId == userLocalId;
});
// User not known
if (iter == _users.end())
{
return;
}
auto handle = iter->Handle();
// If a guest gets signed out, immediately close the handle
bool isGuest;
if (SUCCEEDED_LOG(XUserGetIsGuest(handle, &isGuest)) &&
isGuest &&
event == XUserChangeEvent::SignedOut)
{
_users.erase(iter);
}
if (event == XUserChangeEvent::SigningOut)
{
// Delay the user signing out just for fun
XUserSignOutDeferralHandle deferral;
if (SUCCEEDED_LOG(XUserGetSignOutDeferral(&deferral)))
{
// Hold the deferral for 5 seconds then close it
std::thread completeDeferralThread(
[deferral]()
{
std::this_thread::sleep_for(std::chrono::milliseconds(5000));
XUserCloseSignOutDeferralHandle(deferral);
});
completeDeferralThread.detach();
}
}
if (event == XUserChangeEvent::GamerPicture)
{
iter->LoadGamerPicAsync(_queue);
}
}
요구 사항
헤더: XUser.h
라이브러리: xgameruntime.lib
지원되는 플랫폼: Windows, Xbox One 패밀리 콘솔 및 Xbox Series 콘솔