SchultzGames
Para tirar dúvidas, crie um tópico especifico na área "Dúvidas em Geral" e aguarde ser respondido. Evite comentar em tópicos não relacionados a sua dúvida :D
TÓPICOS RECENTES:
Tópico:
Postado em:
Postado por:
Como usar o touchpad da unity para orbital o personagem em terceira pessoas ?
(Dúvida) Encontrar o objeto mais próximo partindo do ponto inicial ao final.
[TUTORIAL] JavaScript & HTML - Eventos
Unity + Photon 2
[TUTORIAL] Sistema de fome, sede, barra de vida, barra de estamina, itens e dano por queda
Erro MSVehicleController
[____TÓPICO LIVRE____] FALE O QUE QUISER (Parte 2)
[Em Desenvolvimento] Battles of Worlds
Artistas 3D e Programadores Unity3D (Remunerado)
[Modelo 3D]Unity Interior 3D Estilo De Terror + Download Grátis
iniciar jogo com uma cena desativada e ativá-la ao colidir com bloco desativando as outras
Salvar e carregar dados json player pref
Dificuldade no adição do Android SDK a Unity e erro no Android Studio
[TUTORIAL] Sistema de tiro com RAYCAST (várias armas, mira laser, munição, dano, etc, etc)
[TUTORIAL] Sistema de Entregas + GPS!
Como fazer um objeto ter a mesma rotação de outro
Favela Killer Mapa
Servidor De Desenvolvimento De Jogos GGI DISCORD
[Duvida] Script pegar itens
[TUTORIAL] Sistema de vida,morte,dano
[TUTORIAL] Third Person Shooter
[GameJam] Competição organizada pela BitCodeStudios
Como Faz pra barra de vida aparecer de uma cena pra outra?
[____ENQUETE____] Eleições para presidente 2018 (2º turno)
[PROJETO MOBILE] Defeat the Illuminatis
[RESOLVIDO] Problema com cenário infinito ou algum tipo de bug na Unity?
Unity Remota 5, sem reação.
Procuro Equipe Para Criação de Jogo [PAGO]
Procuro Map Designer [PAGO $$$] (criador de mapas)
[TUTORIAL] Sistema de Oficina de Carros
[RESOLVIDO] Unity 2018 - Bug com a iluminação da Spotlight nos Objetos
[TUTORIAL] Menu Pause AVANÇADO (Unity 5.3 ou superior)
[TUTORIAL] Barra de VIDA / HP contínua
Blander ao juntar algumas partes ficam mais escuro
Problema com Esqueleto do personagem
{Possível Projeto para Unity} Buscando membros para formar uma Equipe...
[TUTORIAL] Como spawnar inimigos [Tutorial simples]
Não consigo fazer o box collider descer junto com o personagem.
BUG UNITY 3D ROSA A SCENE E GAME
Sistema de Grau Realista - Jogo de Moto
Programação Unity android 2D
(UNITY) Erro ao compilar a Build Android
Erro na sincronização dos player no Photon
[TUTORIAL] Barra de vida usando a UI da Unity(Slider)
[Projeto] Line Battle
[TUTORIAL] Desbloqueio e Escolha de Personagens.
[RESOLVIDO] Problema com o navmesh agent
[RESOLVIDO] Registro cadrastando uma vez?
Vaga de modelador 3D, com remuneração...
Problemas com Colisores
Como criar Atlas de textura com modelos exportados do Sketchup?
Unity - Sistema de Pagamento
[RESOLVIDO] iniciar áudio ao passar por uma área da cena
[RESOLVIDO] como envia asset para asset store
[TUTORIAL] Mover personagem com Touch, no estilo SUBWAY SURFERS
codigo não deleta prefab e não respeita o if
[TUTORIAL] Filtros de áudio para AudioListner (Low pass filter, High pass filter, etc)
[____CICLO DE TRABALHO DA UNITY____]
Meu jogo não está abrindo em outro PC
[TUTORIAL] DANO POR QUEDA e BARRA DE VIDA CONTÍNUA no mesmo script
Discord para desenvolvimento de jogos
FAB in WWII (Novo jogo na Play Storee é Free :D)
[TUTORIAL] Sistema de PORTAS e CHAVES
Criar uma Array ou List com as resoluções suportadas
Alguem traz esse tutorial pro forum?
Realistic fps prefab tenho esses erros ao tentar colocar um script de entrar sair do carro
[RESOLVIDO] Alguem pode me ajudar? tenho esse erro aqui em um script
[RESOLVIDO] Personagem 2d batendo na borda e voando.
[RESOLVIDO] Não consigo usar o Sphere collider.
[RESOLVIDO] Como usa o UI.Text do unity?
Como criar botão de nova tentativa
[RESOLVIDO] Duvida em Jogo de tiro 2D
[RESOLVIDO] duvida com PlayerPrefs
Iniciar animação em determinado frame
Sistema De Troca De Armas 2D
[TUTORIAL] Script de arma completo! [FREE]
[TUTORIAL] Ordenar valores de uma array[] em ordem CRESCENTE OU DECRESCENTE
Meu jogo de runner em primeira pessoa !
[RESOLVIDO] Timer pra mudar de cena na unity 2018
Atualizar Build
[TUTORIAL] 42 ÓTIMAS DICAS DE OTIMIZAÇÃO PARA JOGOS MOBILE (Android)
Como usar Vector3.Angles para detectar que algo está na frente de outro objeto?
[TUTORIAL] Como fazer porta malas do carro abrir atravez de um botão?
Script nao funciona
Como desativar scripts em objetos distantes
[RESOLVIDO] Bug Da Unity ?
[AULA] HTML - Aula 1: Introdução
Raycast
[TUTORIAL]"Morte" do personagem (Unity 5.3 ou Superior)
Problema com a unity ads
como eu faço para a camera orbitar um objeto atraves de um joystick?????
XML, suporte e utilização.
Arrastar objetos em plano 2D (ArrastarT).
Participe da Game Jam - Jaaj do canal Amdré Young!
Criar sistema de arrastar e soltar objetos em determinado lugar
AWM Champions I
[RESOLVIDO] Como verificar se o objeto é diferente de null
COMO FAÇO PARA FAZER UM SISTEMA DE SKIN PARA ANDROID ESTILO HEAVY BUS, PROTON BUS, ETC
[TUTORIAL] Snake com Unity + C#
Hoje à(s) 1:41 am
Hoje à(s) 12:43 am
Ontem à(s) 10:37 pm
Ontem à(s) 10:37 pm
Ontem à(s) 9:20 pm
Ontem à(s) 8:56 pm
Ontem à(s) 6:34 pm
Ontem à(s) 6:32 pm
Ontem à(s) 4:52 pm
Ontem à(s) 3:46 pm
Ontem à(s) 3:00 pm
Ontem à(s) 1:45 pm
Ontem à(s) 9:58 am
Dom Out 21, 2018 11:29 pm
Dom Out 21, 2018 8:26 pm
Dom Out 21, 2018 8:26 pm
Dom Out 21, 2018 2:26 pm
Dom Out 21, 2018 1:10 pm
Dom Out 21, 2018 11:07 am
Dom Out 21, 2018 9:36 am
Dom Out 21, 2018 1:10 am
Sab Out 20, 2018 4:15 pm
Sab Out 20, 2018 2:48 pm
Sab Out 20, 2018 1:10 pm
Sab Out 20, 2018 11:46 am
Sex Out 19, 2018 10:24 pm
Sex Out 19, 2018 7:51 pm
Sex Out 19, 2018 7:23 pm
Sex Out 19, 2018 7:18 pm
Qui Out 18, 2018 7:09 pm
Qui Out 18, 2018 4:52 pm
Qui Out 18, 2018 2:57 pm
Qui Out 18, 2018 10:36 am
Qua Out 17, 2018 11:45 pm
Qua Out 17, 2018 11:17 pm
Qua Out 17, 2018 10:14 pm
Qua Out 17, 2018 9:49 pm
Qua Out 17, 2018 8:32 pm
Qua Out 17, 2018 5:18 pm
Qua Out 17, 2018 5:16 pm
Qua Out 17, 2018 5:13 pm
Qua Out 17, 2018 5:10 pm
Qua Out 17, 2018 4:35 pm
Qua Out 17, 2018 3:13 pm
Qua Out 17, 2018 7:28 am
Ter Out 16, 2018 3:34 pm
Ter Out 16, 2018 12:41 pm
Ter Out 16, 2018 11:48 am
Seg Out 15, 2018 5:34 pm
Seg Out 15, 2018 5:03 pm
Seg Out 15, 2018 1:19 pm
Seg Out 15, 2018 12:56 pm
Seg Out 15, 2018 11:34 am
Seg Out 15, 2018 6:17 am
Seg Out 15, 2018 12:30 am
Seg Out 15, 2018 12:18 am
Dom Out 14, 2018 12:52 am
Sab Out 13, 2018 9:08 pm
Sab Out 13, 2018 5:24 pm
Sab Out 13, 2018 4:00 pm
Sex Out 12, 2018 6:00 pm
Sex Out 12, 2018 2:56 pm
Sex Out 12, 2018 2:42 pm
Qui Out 11, 2018 8:59 pm
Qui Out 11, 2018 8:32 pm
Qui Out 11, 2018 3:09 pm
Qui Out 11, 2018 2:32 pm
Qui Out 11, 2018 12:15 pm
Qui Out 11, 2018 11:35 am
Qui Out 11, 2018 10:50 am
Qui Out 11, 2018 8:24 am
Qua Out 10, 2018 11:31 pm
Qua Out 10, 2018 10:43 pm
Qua Out 10, 2018 8:22 pm
Qua Out 10, 2018 4:53 pm
Qua Out 10, 2018 4:44 pm
Qua Out 10, 2018 3:48 pm
Qua Out 10, 2018 12:40 pm
Ter Out 09, 2018 9:51 pm
Ter Out 09, 2018 8:16 pm
Ter Out 09, 2018 8:16 pm
Ter Out 09, 2018 8:10 pm
Ter Out 09, 2018 8:09 pm
Ter Out 09, 2018 7:38 pm
Ter Out 09, 2018 2:55 pm
Seg Out 08, 2018 6:13 pm
Seg Out 08, 2018 4:40 pm
Seg Out 08, 2018 2:39 pm
Seg Out 08, 2018 12:52 pm
Seg Out 08, 2018 12:16 pm
Seg Out 08, 2018 10:33 am
Dom Out 07, 2018 1:59 pm
Dom Out 07, 2018 11:53 am
Sab Out 06, 2018 11:14 pm
Sab Out 06, 2018 10:55 pm
Sab Out 06, 2018 8:50 pm
Sab Out 06, 2018 8:41 pm
Sab Out 06, 2018 2:21 pm
Sab Out 06, 2018 1:33 pm
CaioItz
rafaelllsd
MayLeone
ruanzikaad
Pablo Conti
MarcosSchultz
Dom3000
Dom3000
Caio Cesar Miguel
francisco barroso
dstaroski
igorobm
dstaroski
francisco barroso
KAYKETHEO27
ruanzikaad
Isabela
SoullSec
Pablo Conti
francisco barroso
Callyde Jr
hetrodo
hao3726
JohnRambo
dstaroski
FabioBRPA
francisco barroso
SoullSec
SoullSec
leandrospp7
CaerHunter
Mourao
francisco barroso
DominicDK
DominicDK
NoctisLucis
francisco barroso
MayLeone
MarcosSchultz
MarcosSchultz
MarcosSchultz
francisco barroso
hao3726
dstaroski
dstaroski
ismarspn
Jmspp
Callyde Jr
igorobm
conceptfac
Isabela
Callyde Jr
Daniel Dória
diegopds
MarcosSchultz
igorobm
MarcosSchultz
MarcosSchultz
Flávio
francisco barroso
SuperGamer
SoullSec
SoullSec
Flávio
francisco barroso
Samuelostgamer
Samuelostgamer
gurgelg752
luansantos
guimaraf
theus.mors
TecnoGames
Eduardoro39
QueriaStarMorto
QueriaStarMorto
mecjo
NyanHeavyBR
CaioItz
RodriGO3477
MarcosSchultz
MarcosSchultz
MarcosSchultz
MarcosSchultz
FelipeSouza11
FelipeSouza11
QueriaStarMorto
Tegh
Jmspp
Callyde Jr
Jmspp
Gabryellx007
Tegh
Tegh
Luizdanhp
MarcosSchultz
TioUV
QueriaStarMorto
KAYKETHEO27
NKKF

[TUTORIAL] Unity + PHP + Mysql (com PDO)

Ir em baixo

TUTORIAL [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por jasondavin em Ter Fev 27, 2018 11:14 am

Olá galera...

Hoje vim postar um tutorial bem direto que várias pessoas tem dúvidas: Como integrar Unity + PHP + Mysql ?
Vou explicar em passos, colocando o trecho de código e dando uma breve resumida da lógica do algoritmo. Também não vou fazer a parte de UI no Unity pois não é o foco.

Tecnologias utilizadas:
- Appserv 8.6.0 (Servidor PHP) ~> Link aqui
- PHP 7.0
- Mysql 5.7

Script do banco de dados Mysql

Código:
CREATE DATABASE minhadb;
USE minhadb;

CREATE TABLE usuarios
(
    _id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
    _username VARCHAR(25) NOT NULL UNIQUE,
    _password VARCHAR(25) NOT NULL
);


Lado servidor PHP


1. Criando arquivo de configuração



Código:
<?php
// Configuracoes mysql
DEFINE("HOST","127.0.0.1");
DEFINE("USER","root");
DEFINE("PASSWORD","teste");
DEFINE("DATABASE","minhadb");
?>


Esse código define constantes contendo o HOST (IP), usuário, senha do banco de dados e a database que será utilizada na conexão Mysql.


2. Criando classe de Conexão PDO com um banco de dados (não necessariamente Mysql, pois estamos tratando de conexão PDO)



Código:
<?php
if(!class_exists("Connector"))
{
   class Connector
   {
      private $con = NULL;

      public function __construct()
      {
         $this->connect();
      }

      protected function connect()
      {
         try {
            $this->con = new PDO("mysql:host=".HOST.";dbname=".DATABASE, USER, PASSWORD);
         }
         catch(PDOException $e)
         {
            die($e->getMessage());
         }
         return $this->con;
      }

      public function execute($sql)
      {
         return $sql->execute();
      }

      public function prepare($stmt)
      {
         return $this->con->prepare($stmt);
      }

      public function fetch($stmt)
      {
         return $stmt->fetch(PDO::FETCH_ASSOC);
      }

      public function numRow($stmt)
      {
         return $stmt->rowCount();
      }

      public function close() {
         try {
            $this->con = NULL;
         }
         catch(PDOException $e) {
            exit($e->getMessage());
         }
      }
   }
}
?>


Essa classe contem os métodos básicos e principais para conexão com um banco de dados e manipulação de instruções sql. Não vou me explicar muito sobre essa classe, mas se quiser dar uma olhada em um projeto de TCC que eu fiz no meu curso ~> FastTCC


3. Criando arquivos de registro e login


login.php
Código:
<?php
// Importando arquivos de configuracao e classe de conexao
require "config.php";
require "Connector.class.php";

$conn = new Connector();

// Declaracao da variavel que ira conter a mensagem de erro
$result = array(
    "error" => true,
    "message" => ""
);

// Verificando se existe variaveis POST
if(isset($_POST["username"], $_POST["password"]))
{
    // Prepara instrucao SQL
    $stmt = $conn->prepare("SELECT * FROM usuarios WHERE _username = ? AND _password = ?");
    // Configura os parametros da instrucao
    $stmt->bindValue(1, $_POST["username"], PDO::PARAM_STR);
    $stmt->bindValue(2, $_POST["password"], PDO::PARAM_STR);

    // Executa instrucao
    if($stmt->execute())
    {
          // Verifica se houve resultados da instrucao
          if($conn->numRow($stmt) > 0)
          {
              // Guarda o resultado
              $row = $conn->fetch($stmt);
              $result["error"] = false;
              $result["message"] = "login successful.";
              $result["_userid"] = (int)$row["_id"];
              $result["_username"] = $row["_username"];
          }
          else {
              $result["message"] = "user incorrect.";
          }
    }
    else {
          $result["message"] = "error in server.";
    }
}
else
{
    $result["message"] = "fill all fields.";
}

// Decodifica a variavel contendo a mensagem de erro para JSON
$result_json = json_encode($result);
// Fecha conexao Mysql
$conn->close();
// Retorna dados para o client
exit($result_json);
?>

register.php
Código:
<?php
require "config.php";
require "Connector.class.php";

$conn = new Connector();

$result = array(
    "error" => true,
    "message" => ""
);

if(isset($_POST["username"], $_POST["password"]))
{
    $stmt = $conn->prepare("INSERT INTO usuarios SET _username = ?, _password = ?");
    /*
    * Tambem podendo ser:
    * "INSERT INTO usuarios (_username,_password) VALUES (?,?)"
    */
    $stmt->bindValue(1, $_POST["username"], PDO::PARAM_STR);
    $stmt->bindValue(2, $_POST["password"], PDO::PARAM_STR);

    if($stmt->execute())
    {
          $result["error"] = false;
          $result["message"] = "registered with success.";
    }
    else {
          $result["message"] = "not registered.";
    }
}
else
{
    $result["message"] = "fill all fields.";
}

$result_json = json_encode($result);
$conn->close();
exit($result_json);
?>

Os dois arquivos são bem parecidos, mudando apenas na instrução SQL e o tratamento das informações. Ambos importam o arquivo de configuração (citado no 1º passo) e a classe de conexão (citado no 2º passo). Verificam se existe as variáveis POST "username" e "password" para a construção da instrução SQL.
A instrução é executada e com as informações retornadas, é criada uma variável contendo o resultado da instrução e logo em seguida, é convertido em JSON e finalmente retornada para o cliente.

Lado cliente C#



Código:
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class Manager : MonoBehaviour {

    private void Start()
    {
        StartCoroutine("Register");
        StartCoroutine("Login");
    }

    IEnumerator Login()
    {
        // Criando formulario e configurando variaveis de parametro
        WWWForm form = new WWWForm();
        form.AddField("username", "jason"); // Parametro username
        form.AddField("password", "123");  // Parametro password

        // Chamando e enviando variaveis para uma URL
        WWW www = new WWW("http://127.0.0.1/tutorial/login.php", form);

        yield return www;

        // Verificando se nao houve erro na requisicao
        if(www.error == null)
        {
            // Cria um objeto do tipo Message contendo a resposta da requisicao
            Message jsonReturn = Message.decodify(www.text);
            // Mostra a mensagem de retorno
            Debug.Log(jsonReturn.message);
        }
    }

    IEnumerator Register()
    {
        WWWForm form = new WWWForm();
        form.AddField("username", "jason");
        form.AddField("password", "123");

        WWW www = new WWW("http://127.0.0.1/tutorial/register.php", form);

        yield return www;

        if (www.error == null)
        {
            Message jsonReturn = Message.decodify(www.text);
            Debug.Log(jsonReturn.message);
        }
    }
}

// Classe criada para converter a resposta da requisicao (string / JSON) em um objeto em C#
[System.Serializable]
public class Message
{
    public string message;
    public bool error;
    public int _userid;
    public string _username;

    public static Message decodify(string _text)
    {
        return JsonUtility.FromJson<Message>(_text);
    }
}



Esse arquivo C# possui duas Coroutines e uma classe serializada.

Classe Message


Essa classe é criada com objetivo de converter o retorno do PHP (que é uma string no formato JSON) para um objeto em PHP.
Obs: os atributos criados nesta classe deve conter exatamente o mesmo nome das propriedades criada no PHP.

Coroutine Login & Register


Cria um WWWForm contendo os parâmetros username e password que são utilizados para fazer a instrução SQL no arquivo PHP. Tal formulário é enviado como parâmetro na chamada da URL pelo objeto WWW.
Depois de instanciado, é feito uma verificação se não houve erro na requisição. Caso não houver, é criado um objeto do tipo Message que converte as informações retornadas do PHP para um objeto em C#.

Ponto importante:

Caso você queira acessar um banco de dados externo, você deverá mudar apenas na URL passada na instância do Objeto WWW. Por exemplo:
Código:
WWW www = new WWW("http://seusite.com/sua_pasta/arquivo.php", form);


Caso este tutorial não foi claro o bastante (pois não sou bom em explicar) poste sua dúvida que tentarei responde-la.
avatar
jasondavin
MembroAvançado

Masculino PONTOS : 460
REPUTAÇÃO : 16
Idade : 19
Áreas de atuação : Programação Web
GitHub : www.github.com/jasondavindev
Projeto: www.teamdev.pe.hu
Respeito as regras :

Ver perfil do usuário http://jasondavin.xyz

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por fabriciorsz34 em Ter Fev 27, 2018 12:33 pm

Wow
avatar
fabriciorsz34
Programador

PONTOS : 1115
REPUTAÇÃO : 24
Idade : 18
Áreas de atuação : C#,unity,cinema 4D, SketchUp

Respeito as regras :

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Dom3000 em Ter Fev 27, 2018 2:59 pm

muito bom parabens  Laughing
avatar
Dom3000
Programador

Masculino PONTOS : 2273
REPUTAÇÃO : 209
Idade : 22
Áreas de atuação : canal https://www.youtube.com/watch?v=yvmQEJUfbhQ
Page: https://www.facebook.com/BatlesofWorlds/
Ble
Respeito as regras :

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Cezar2016 em Ter Fev 27, 2018 5:40 pm

Parabéns pelo tutorial.

Cezar2016
Avançado
Avançado

Masculino PONTOS : 881
REPUTAÇÃO : 26
Respeito as regras :

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Dom3000 em Qua Fev 28, 2018 9:33 am

tenho uma duvida tipo eu tenho um game quase pronto, mas é single uso C# normal, para eu fazer ele ser multiplayer vou ter que mudar os scripts dele?
avatar
Dom3000
Programador

Masculino PONTOS : 2273
REPUTAÇÃO : 209
Idade : 22
Áreas de atuação : canal https://www.youtube.com/watch?v=yvmQEJUfbhQ
Page: https://www.facebook.com/BatlesofWorlds/
Ble
Respeito as regras :

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por NKKF em Qua Fev 28, 2018 2:10 pm

Sim, com certeza você terá que mudar muita coisa. Caso contrário, poderá ter problemas. Lembre-se de sempre fazer um BKUP do jogo singleplayer e do progresso dele.  :D
avatar
NKKF
ProgramadorMaster

Masculino PONTOS : 1995
REPUTAÇÃO : 405
Idade : 14
Áreas de atuação : Error 404 Not Found.
Respeito as regras :

Ver perfil do usuário http://www.projetounity.esy.es

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Andeton em Ter Mar 27, 2018 7:13 am

bom tutorial, fiz algo assim há alguns meses mais em vez de usar PDO usei mysqli, e em vez de json usei xml

Andeton
Iniciante
Iniciante

PONTOS : 599
REPUTAÇÃO : 0
Respeito as regras :

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por amchacon em Ter Mar 27, 2018 9:02 pm

Muito bom. Eu mudaria apenas poucas coisas.

O campo password no banco, colocaria VARCHAR(255)
_password VARCHAR(255) NOT NULL
E adicionaria o campo '_status' como tinyint(1) para podermos rapidamente desativar um usuáro para que não possa mais logar.


E, no C#, antes de adicionar a senha no WWWForm, converteria para MD5. Assim, a senha já vai mais segura no pacote do POST.

amchacon
Iniciante
Iniciante

PONTOS : 939
REPUTAÇÃO : 0
Respeito as regras :

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Yan em Sab Maio 19, 2018 8:54 pm

Estou na duvida para configurar os  input fields.
Alguém pra explicar.

Yan
Iniciante
Iniciante

PONTOS : 730
REPUTAÇÃO : 0
Respeito as regras :

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Callyde Jr em Dom Maio 20, 2018 8:58 am

Se voce for usar input fields ele fica assim
Código:
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class Manager : MonoBehaviour {
 
    public InputField InputUsername;//Adicione o input
    public InputField InputPassword;//Adicione o input
 

    private void Start()
    {
        StartCoroutine("Register");
        StartCoroutine("Login");
    }

    IEnumerator Login()
    {
        // Criando formulario e configurando variaveis de parametro
        WWWForm form = new WWWForm();
        form.AddField("username", InputUsername.text); // Parametro username
        form.AddField("password", InputPassword.text);   // Parametro password

        // Chamando e enviando variaveis para uma URL
        WWW www = new WWW("http://127.0.0.1/tutorial/login.php", form);

        yield return www;

        // Verificando se nao houve erro na requisicao
        if(www.error == null)
        {
            // Cria um objeto do tipo Message contendo a resposta da requisicao
            Message jsonReturn = Message.decodify(www.text);
            // Mostra a mensagem de retorno
            Debug.Log(jsonReturn.message);
        }
    }

    IEnumerator Register()
    {
        WWWForm form = new WWWForm();
        form.AddField("username", InputUsername.text);
        form.AddField("password", InputPassword.text);

        WWW www = new WWW("http://127.0.0.1/tutorial/register.php", form);

        yield return www;

        if (www.error == null)
        {
            Message jsonReturn = Message.decodify(www.text);
            Debug.Log(jsonReturn.message);
        }
    }
}

// Classe criada para converter a resposta da requisicao (string / JSON) em um objeto em C#
[System.Serializable]
public class Message
{
    public string message;
    public bool error;
    public int _userid;
    public string _username;

    public static Message decodify(string _text)
    {
        return JsonUtility.FromJson<Message>(_text);
    }
}
avatar
Callyde Jr
Programador

Masculino PONTOS : 2685
REPUTAÇÃO : 364
Idade : 39
Áreas de atuação : Iniciante em modelagem Blender,ScketSHUP
Progamador
Ideialista

Meu Canal
https://www.youtube.com/ch
Respeito as regras :

Ver perfil do usuário http://unnygames.000webhostapp.com/

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Yan em Dom Maio 20, 2018 3:36 pm

Ainda não foi muito claro.
Sou iniciante.
Não sei como dizer para apertar no botão e logar só se as informações estiverem corretas.
O mesmo para o botão registrar.
Facilitaria usando o OnClick.

Yan
Iniciante
Iniciante

PONTOS : 730
REPUTAÇÃO : 0
Respeito as regras :

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Callyde Jr em Dom Maio 20, 2018 6:53 pm

Bom ele colocou tudo no start
Bom eu fiz umas alteraçoes no script mais acho que fica mais facil de enteder
Código:
using System.Collections;
    using System.Collections.Generic;
    using UnityEngine;
    using UnityEngine.UI;

    public class Manager : MonoBehaviour {
   
        public InputField InputUsername;//Adicione o input
        public InputField InputPassword;//Adicione o input
        public Text textoRetorno = null;//UI textpara aparecer o retorno
        public GameObject canvasLogin,canvasRegister;//Os canvas para separar
      
        private void Start()
        {
            canvasLogin.SetActive(true);
            canvasRegister.SetActive(false);
        }
      
      public void Register()//ir para canvas registro
        {
            canvasRegister.SetActive(true);
            canvasLogin.SetActive(false);
      }
      public void ReturnToLogin()//ir para canvas login
        {
            canvasLogin.SetActive(true);
            canvasRegister.SetActive(false);
      }
      
      public void LogarUsuario(){//Funçao para fazer login
       if(InputUsername.text == "" || InputPassword.text == ""){//Para nao cadrastar usuariosvazios
      textoRetorno.text = "Nao pode existir campo vasios";
      print("Nao pode existir campo vasios");
      return;
   }   
    StartCoroutine("Login");
   }
   public void registrarNovoUsuario()//Funçao para cadrato
    {
        if(InputUsername.text == "" || InputPassword.text == "")
        {
            textoRetorno.text = "Prencha todos os campos!";
            print("Prencha todos os campos!");
            return;
        }
        StartCoroutine("Register");
    }   
      

        IEnumerator Login()
        {
            // Criando formulario e configurando variaveis de parametro
            WWWForm form = new WWWForm();
            form.AddField("username", InputUsername.text); // Parametro username
            form.AddField("password", InputPassword.text);  // Parametro password

            // Chamando e enviando variaveis para uma URL
            WWW www = new WWW("http://127.0.0.1/tutorial/login.php", form);

            yield return www;

            // Verificando se nao houve erro na requisicao
            if(www.error == null)
            {
                // Cria um objeto do tipo Message contendo a resposta da requisicao
                Message jsonReturn = Message.decodify(www.text);
                // Mostra a mensagem de retorno
                Debug.Log(jsonReturn.message);
            }
        }

        IEnumerator Register()
        {
            WWWForm form = new WWWForm();
            form.AddField("username", InputUsername.text);
            form.AddField("password", InputPassword.text);

            WWW www = new WWW("http://127.0.0.1/tutorial/register.php", form);

            yield return www;

            if (www.error == null)
            {
                Message jsonReturn = Message.decodify(www.text);
                Debug.Log(jsonReturn.message);
            }
        }
    }

    // Classe criada para converter a resposta da requisicao (string / JSON) em um objeto em C#
    [System.Serializable]
    public class Message
    {
        public string message;
        public bool error;
        public int _userid;
        public string _username;

        public static Message decodify(string _text)
        {
            return JsonUtility.FromJson<Message>(_text);
        }
    }
avatar
Callyde Jr
Programador

Masculino PONTOS : 2685
REPUTAÇÃO : 364
Idade : 39
Áreas de atuação : Iniciante em modelagem Blender,ScketSHUP
Progamador
Ideialista

Meu Canal
https://www.youtube.com/ch
Respeito as regras :

Ver perfil do usuário http://unnygames.000webhostapp.com/

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Yan em Seg Maio 21, 2018 4:55 pm

Exelente estou conseguindo conectar ao banco de dado efetuando registro e fazendo login.
Porém... Tentei fazer com que quando aperto para logar vá para a outra cena e não consegui.
Utilizei algo como.
Código:
IEnumerator CarregarCena () {
      yield return new WaitForSeconds (3);
      Application.LoadLevel ("Nome da cena");
   }


mas quando colocava o
StartCoroutine (CarregaScene());
no
IEnumerator Login()
passava sem precisar de senha.
Como disse sou iniciante, script não é muito comigo, mas eu tento. É muita coisa de uma vez, fazer modelos, texturas, animações, scripts... Desculpa o incomodo. E muito obrigado por me ajudar. Olhando aprendi métodos.

Yan
Iniciante
Iniciante

PONTOS : 730
REPUTAÇÃO : 0
Respeito as regras :

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Callyde Jr em Seg Maio 21, 2018 6:51 pm

Use
Código:
using UnityEngine.SceneManagement;

SceneManager.LoadScene ("Login");//Para chamar a scene
avatar
Callyde Jr
Programador

Masculino PONTOS : 2685
REPUTAÇÃO : 364
Idade : 39
Áreas de atuação : Iniciante em modelagem Blender,ScketSHUP
Progamador
Ideialista

Meu Canal
https://www.youtube.com/ch
Respeito as regras :

Ver perfil do usuário http://unnygames.000webhostapp.com/

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Callyde Jr em Ter Maio 22, 2018 5:56 am

Para verificar o retorno e aplicar a passagem de scene voce tem que ver o retorno do PHP Veja no exemplo abaixo.
Código:
if( mensage == "registered with success" ){
      
      yield return new WaitForSeconds (5);
              SceneManager.LoadScene ("Login");
avatar
Callyde Jr
Programador

Masculino PONTOS : 2685
REPUTAÇÃO : 364
Idade : 39
Áreas de atuação : Iniciante em modelagem Blender,ScketSHUP
Progamador
Ideialista

Meu Canal
https://www.youtube.com/ch
Respeito as regras :

Ver perfil do usuário http://unnygames.000webhostapp.com/

Voltar ao Topo Ir em baixo

Voltar ao Topo

- Tópicos similares

 
Permissão deste fórum:
Você não pode responder aos tópicos neste fórum