Problems retrieving an item ID in the Grid

Hello guys! So … I had some problems with the grid and the flow of my code and I came to ask for your help.

Last night I started working on a project and tried to make a menu with scroll view and grid, I created a button for each category and this button calls a grid-controlled prefab (see the image to understand better), in theory I am trying to retrieve the id of the menu items and clicking on them makes them visible on the screen, in theory until it works, but I’m having trouble putting it into practice … any suggestions?

This is code that I started to make, I don’t know if it’s too early to ask for help, but I’m having problems with that…
If you have any suggestions on how this can work better I would be very happy!! :slight_smile:

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;

public class Skincontroller : MonoBehaviour
{

    public GameObject panelcontrol;
    public Image prefabcontrol;

    public Sprite[] skintone = new Sprite [7];

    void Start()
    {


        foreach (Transform child in panelcontrol.transform)
        {
            GameObject.Destroy(child.gameObject);
        }

        skintone = Resources.LoadAll<Sprite>("Icones/SknIcon");

        for (int qntdskin = 0; qntdskin < skintone.Length; qntdskin++)
        {

            prefabcontrol = Instantiate(prefabcontrol, new Vector2(0, 0), Quaternion.identity, panelcontrol.transform);
            prefabcontrol.sprite = skintone[qntdskin];
        }
    }

This is the section that controls the call:

    public void LoadSkin()
    {

        GetComponent<Skincontroller>().enabled = true;

    }

I’m not 100% sure what it is you’re stuck with … but it looks like what you’re trying to achieve is to have separate panels (e.g. for skin colour, eyebrows, eyes etc), and then each panel has multiple options you can choose from (e.g. white skin, brown skin, green skin [:smile:]).

I’m also guessing you want it to be dynamically loading and not hard-coded (so e.g. you can just create a new icon in Icones/SknIcon and a new button will appear and work).

What I would do is something like this:

  • Create a prefab with a class called SkinButton.

  • On loading the skin colour panel, the SkinController would load the Icones/SknIcon folder, and for each icon it found, it would instantiate a different button (the SkinButton prefab) inside the grid, also passing to the button a reference to its own texture.

  • In every button’s onpress event would be a function like OnButtonPressed(), which would call something like SkinController.OnPressSkinChoice(Texture2D skintexture), passing that button’s skin colour to the SkinController.

  • The SkinController would then set the skin colour of the character.

Not sure if that is helpful but feel free to ask if you get stuck.

Thankss!!! -
Well, I tested your instructions and it worked beautifully!
But now I’m having trouble resetting the prefab, let’s say I can only open the category once and then I can’t go back to the previous one.
But at least the character already changes clothes haha
It is a pity that I am facing this new problem.