Add player search menu - Search for players - (Unity module)
What's on the menu
In this tutorial, you will learn how to prepare the user interface (UI) you will use to find players by their display name and send friend invitation requests. The files are available in the Resources sections and consists of the following:
- FindFriendsMenuCanvas_Starter: A UI menu to search for players by their display name or friend code.
- CS file:
/Assets/Resources/Modules/FriendsEssentials/Scripts/UI/FindFriendsMenuHandler_Starter.cs
. - Prefab file:
/Assets/Resources/Modules/FriendsEssentials/Prefabs/FindFriends/FindFriendsMenuCanvas_Starter.prefab
- CS file:
- FindFriendsEntryComponent: A UI component to display the player information, such as display name, avatar, and a send friend invite button.
- CS file:
/Assets/Resources/Modules/FriendsEssentials/Scripts/UI/FindFriendsEntryHandler.cs
- Prefab file:
/Assets/Resources/Modules/FriendsEssentials/Prefabs/FindFriends/FindFriendsEntryComponent.prefab
- CS file:
Take a look at the prefabs of these UI menus for more detailed information.
Find Friends Menu Canvas
Below is the preview of the FindFriendsMenuCanvas_Starter.prefab
. This menu consists of the following components:
- Friend Code Text: A text field to input the friend code.
- Copy Code Button: A button to copy the friend code.
- Search Bar: A text field to input the display name of the player you want to find.
- Search Button: A button to search for the player by their display name.
This menu also has several panels to display the search result, such as the default panel, loading panel, loading failed panel, and the search result panel.
The search bar and the list that show the found player entries are defined in the FindFriendsMenuHandler_Starter.cs
script. The script has the following fields to store the UI references:
[Header("Find Friends Components"), SerializeField] private GameObject friendEntryPrefab;
[SerializeField] private TMP_Text friendCode;
[SerializeField] private Button friendCodeCopyButton;
[SerializeField] private TMP_InputField friendSearchBar;
[SerializeField] private Button friendSearchButton;
[Header("View Panels"), SerializeField] private RectTransform defaultPanel;
[SerializeField] private RectTransform loadingPanel;
[SerializeField] private RectTransform loadingFailedPanel;
[SerializeField] private RectTransform resultContentPanel;
This menu displays one player entry at a time upon a successful search instantiated in the resultContentPanel
field. The script has the following property to store the current player entry:
private GameObject userResult;
The FindFriendsView
enum is used to define the different views of the menu, such as the default view, loading view, loading failed view, and the search result view.
private enum FindFriendsView
{
Default,
Loading,
LoadFailed,
LoadSuccess
}
The CurrentView
property acts as a switch to show the corresponding panel based on the current view.
private FindFriendsView currentView = FindFriendsView.Default;
private FindFriendsView CurrentView
{
get => currentView;
set
{
defaultPanel.gameObject.SetActive(value == FindFriendsView.Default);
loadingPanel.gameObject.SetActive(value == FindFriendsView.Loading);
loadingFailedPanel.gameObject.SetActive(value == FindFriendsView.LoadFailed);
resultContentPanel.gameObject.SetActive(value == FindFriendsView.LoadSuccess);
currentView = value;
}
}
You can use the ClearSearchPanel()
method to clear the search panel and destroy the current player entry.
private void ClearSearchPanel()
{
resultContentPanel.DestroyAllChildren();
if (userResult != null)
{
Destroy(userResult);
}
}
The OnFriendCodeCopyButtonClicked()
method is called when the player clicks the copy button. This method copies the friend code to the clipboard and displays a message to inform the player that the friend code has been copied.
private async void OnFriendCodeCopyButtonClicked()
{
GUIUtility.systemCopyBuffer = friendCode.text;
TMP_Text buttonText = friendCodeCopyButton.GetComponentInChildren<TMP_Text>();
string originalText = buttonText.text;
buttonText.SetText(FriendsHelper.FriendCodeCopiedMessage);
friendCodeCopyButton.interactable = false;
await Task.Delay(TimeSpan.FromSeconds(2));
buttonText.SetText(originalText);
friendCodeCopyButton.interactable = true;
}
Find Friends Entry Component
Below is the preview of the FindFriendsEntryComponent.prefab
. This prefab displays player information, such as a display name, avatar, and a send friend invite button.
This prefab has a script component called FindFriendsEntryHandler.cs
which holds the UI references for the display name, avatar, and the send invite button. The script has the following public getters and property to let other object change the information displayed.
public string UserId { get; set; } = string.Empty;
public Image FriendImage => friendImage;
public TMP_Text FriendName => friendName;
public TMP_Text FriendStatus => friendStatus;
public Button SendInviteButton => sendInviteButton;
Ready the UI
To prepare the UI prefabs, follow these steps:
Open
FindFriendsMenuHandler_Starter.cs
and locate theFindFriend()
method. This method is called when the player presses the Enter key or clicks the search button. For now, it only logs a warning message.private void FindFriend(string query)
{
BytewarsLogger.LogWarning("The FindFriend method is not implemented yet");
}In Unity Editor, go to
Assets/Resources/Modules/FriendsEssentials
. You will find an asset config calledFriendsEssentialsAssetConfig
. Open it and enableIs Starter Active
. This will activate the friends-related UI starter files.Play the game in Unity Editor. If the implementation was successful, you will be able to navigate to Social > Find Friends. Try to find a friend by clicking on the text input and pressing Enter or clicking the search button. You will see a warning message in the console.
[FindFriendsMenuHandler_Starter] [FindFriend] [Warning] [85] - The FindFriend method is not implemented yet
Resources
- The files used in this tutorial are available in the Unity Byte Wars GitHub repository.
- Assets/Resources/Modules/FriendsEssentials/FriendEssentialsAssetConfig.asset
- Assets/Resources/Modules/FriendsEssentials/Scripts/FindFriendsMenuHandler_Starter.cs
- Assets/Resources/Modules/FriendsEssentials/Scripts/FindFriendsMenuCanvas_Starter.prefab
- Assets/Resources/Modules/FriendsEssentials/Prefabs/FindUser/FriendEntryComponent.prefab
- Assets/Resources/Modules/FriendsEssentials/Scripts/UI/FindFriendsEntryHandler.cs