Fastbar
Powrót do strony głównej
Trzymaj pliki na gmclan.org!
Game Maker w pytaniach i odpowiedziach!
Polska dokumentacja
Tabela wyników ligi 24
Pobierz GM
Akademia GMCLANu
Kategorie bazy artykułów
Artykuły -> Game Maker
Treść artykułu
Tutoriale 39dll. Tłumaczenie.
autor: 39ster, Mimek (5.07.09)
stron: 2

1

2

W tym artykule nauczę Cie jak używać39dll zrobionego przez 39stera, do tego, aby zrobić swoją własną grę online. Będziemy posługiwać się przykładem PONG, który znajduje się w paczce z 39dll. :)
INICJACJA DLLA
Aby dll funkcjonował należy podczepić jego skrypty do gry :
Otwieramy GMa > Z menu wybieramy Scripts > Import Scripts > Dllscripts.gml z folderu, gdzie znajduje się 39dll z wszystkimi plikami.
Po imporcie skryptów inicjujemy dlla za pomocą kodu:

kod:
dllinit(0, true, false);


Jeśli pierwszy argument jest liczbą zostaje załadowana domyślna nazwa dlla(39dll.dll). Jeśli dll ma inną nazwę(np. socket.dll) należy ją podać właśnie w tym argumencie.
Drugi argument odpowiada za używanie winsock, w tym przypadku jest to konieczne.
Trzeci argument powinien być ustawiony na true jeżeli chcemy używać funkcji związanymi z plikami. W przykładnie dołączonym do 39dll jest ustawiony na false, gdyż nie potrzebujemy tych funkcji.
STAWIANIE SERWERA:
Aby stworzyć grę multiplayer, jedna osoba musi postawić serwer, czyli hostować, a druga osoba musi się pod ten serwer podłączyć.
Jeżeli chcesz dać możliwość postawienia serwera za pomocą tego dlla musisz stworzyć obiekt, który będzie obsługiwał ustawienia serwera i akceptował nowe połączenia. Przejdźmy do praktyki.
     
Tworzymy dwa obiekty, które będą przyciskami, nadajemy im spritea. Jeden przycisk to HOST, drugi CONNECT. Kiedy gracz wybierze HOST jego kod:

kod:
global.master = true; // hostowanie


powinien wyglądać tak jak ten wyżej. Powinniśmy teraz stworzyć nowy room, do którego będzie przenosić, gdy klikniemy HOST. Nazwijmy go rmWaiting. Teraz stwórzmy nowy obiekt: objWait. W CREATE tego obiektu umieszczamy kod:
kod:

listen = tcplisten(14804, 2, true); //nasłuchiwanie
if(listen, <= 0) //jeśli nie udaje się połączyć
{
show_message("Failed to listen on port 14804); //pokaż wiadomość
game_end(); //zakończ grę
}

Kod ten tworzy nowy socket : nasłuchiwanie. Nasłuchuje on przychodzące połączenia na porcie 14804. Numer portu może być taki, jaki sobie wybierzesz, ale my używamy tutaj 14804. Drugi argument oznacza maksymalną możliwą liczbę połączeń na liście. PAMIĘTAJ : TO NIE JEST MAKSYMALNA MOŻLIWA ILOŚĆ GRACZY W GRZE. Jeśli ktoś stara się dołączyć do gry, to zostaje zapisany na listę, wtedy serwer może zaakceptować jego połączenie. Ostatni argument jest na true, bo nie chcemy zamrażać nasłuchiwania, gdy użyjemy skryptu tcpaccept();. SoCket ten zwróci nam numer identyfikacyjny, który będzie większy niż 0, gdy połączenie osiągnie sukces. Jeśli nie uda nam się połączyć zwracamy numer niższy bądź równy 0.
Kolejna linijka kodu sprawdza, czy nasłuchiwanie jest pozytywne, czy nie. Jeśli nie to wtedy wyświetla wiadomość, iż nie udało nam się połączyć z serwerem i kończy grę.

AKCEPTOWANIE POŁĄCZEŃ
Aby zaakceptować nowe połączenia musimy w evencie STEP obiektu objWait dać kod:
kod:
client = tcpaccept(listen, true);
if(client <= 0) exit;
global.otherplayer = client;
room_goto(rmGame);

Pierwsza linijka sprawdza listę oczekujących na połączenie, czyli po prostu czy ktoś nie próbuje podłączyć się do serwera. Jeśli nikt nie stara się podłączyć zwraca liczbę mniejszą niż 1. Ale jeśli ktoś próbuje się połączyć, to tworzy nowy socket i zwraca jego ID. Będzie on używany do komunikacji(wymiana danych) z graczem, który właśnie dołączył do gry.
Drugi argument w tcpaccept oznacza, że nowy socket będzie działał w trybie nieblokującym. Oznacza to, że jeśli będziesz próbował odebrać wiadomość, to nie zamrozi gry, jeśli nie ma żadnej wiadomości do odebrania.
Druga linijka sprawdza czy tcpaaccept() nie ma czasem błędu. Jeśli napotka błąd, to kończy działanie skryptu. Trzecia i czwarta linijka będą wykonane tylko wtedy, gdy tcpaccept() zadziała bezbłędnie. Trzecia linijka ustawia nam nową zmienną globalną global.otherplayer na ID socketu, które zwróciła dunkcja tcpaccept().
Czwarta linijka przenosi nas do roomu z rzeczywistą grą, którego musisz stworzyć.
Łączenie się z serwerem
Jeśli chcesz dołączyć do gry multiplayer, to musisz połączyć się z serwerem. W roomie, w którym masz dwa przyciski, przycisk HOST ma już swój kod, a teraz zajmiemy się przyciskiem CONNECT, w evencie kliknięcia myszką wpisujemy kod :
kod:
global.master = false;
server = tcpConnect("127.0.0.1", 14804, true);
if(server <= 0)
{
show_message( "Unable to connect to server" )
game_end();
}
global.otherplayer = server;
room_goto(rmGame);

Pierwsza linijka ustawia naszą zmienną globalną master na false, dlatego, że nie jesteśmy serwerem. Jesteśmy natomiast klientem łączącym się z serwerem. Druga linijka kodu wykonuje skrypt, dzięki któremu łączymy się z srewerem. Pierwszym argumentem w tcpConnect() jest adres IP serwera, jeżeli testujesz lokalnie(na localhoscie) użyj adresu 127.0.0.1.Drugi argument to numer portu, z którym się łączymy. Trzeci argument oznacza, czy używamy trybu blokującego czy nieblokującego. Ustawiliśmy go na true co oznacza tryb nieblokujący. Tryb ten służy temu, że jeżeli próbujemy odebrać lub wysłać wiadomość, to gra nie zamraża się(nie zwalnia i nie wiesza się) dopóki operacja się nie skończy.
Jeśli tcpConnect połączył się z sukcesem i został zaakceptowany przez serwer, to zmienna Server powinna wynosić tyle ile wynosi numer socketu. Jeżeli zaś wystąpiły błędy, to zwróci liczbę mniejszą niż 1. Kolejna linijka sprawdza właśnie, czy nie ma błędów. Błąd może wystąpić jeśli serwer nie istnieje, bądź nie zaakceptował naszego podłączenia. Jeśli wystąpił błąd to gra nas o tym poinformuje i się samoistnie zakończy. Jeśli zaś udało się pozytywnie połączyć z serwerem, a on nas zaakceptował, to zmienna globalna otherplayer będzie wynosiła tyle ile zmienna Server. Gra rozpocznie się, jeśli przejdziemy do roomu z grą.


Wysyłanie i odbiór wiadomości.
Aby nasza gra działała normalnie, to musimy znać pozycję paletek i piłeczki. Paletki sterowane są przez graczy, a piłeczka przez serwer. Zajmiemy się teraz wysyłaniem i odbiorem wiadomości.
Wysyłanie
Kontrolując paletkę, musisz wysyłać swoją pozycję Y do innego gracza, aby mógł, a raczej jego gra, narysować Twoją paletkę w odpowiednim miejscu. Aby to zrobić umieszczamy kod w eventach naciśnięcia strzałki w górę i w dół.
kod:

clearbuffer();
writebyte(0);
writeshort(y);
sendmessage(global.otherplayer);

Pierwsza linijka czyści bufor wewnętrzny z wszystkich zbędnych informacji. Druga linijka wysyła do buforu bajt, oznaczający ID wiadomości. W naszej grze wiadomość ID=0 będzie oznaczało pozycję Y paletki. Następna linijka wysyła do buforu aktualną pozycję Y, używając konstrukcji short, ponieważ można używać jej do przesyłania każdej liczby od -32000 do +32000. Zajmuje ona dwa bajty. Jeśli użyjemy tylko jednego bajta, by zaprezentować pozycję Y, a ta wyniesie więcej niż 255 to skończy się rozmiar bajtu, a to spowoduje błąd. Ostatnia linijka wysyła wszystkie wiadomości z buforu do innego gracza. W tym przypadku wysyła 3 bajty. Jeden jako ID wiadomości, a dwa jako pozycję Y/
Teraz musimy wysłać pozycję X oraz Y piłeczki do innego gracza, ale tylko jeśli jesteśmy serwerem. Aby to zrobić umieszczamy ten kod w evencie step piłeczki:
kod:

if(!global.master)exit;
clearbuffer();
writebyte(1);
writeshort(x);
writeshort(y);
sendmessage(global.otherplayer);

Pierwsza linijka sprawdza czy jesteśmy serwerem. Jeśli NIE to kod poniżej nie zostanie wykonany.
Ale jeśli jesteśmy serwerem to pierwsza linijka czyści bufor. Teraz wysyła do niego bajta z ID wiadomości, która będzie oznaczała pozycję piłeczki. Jej ID=1. Następnie zostaje wysłana pozycja X za pomocą konstrukcji short. Analogicznie z pozycją Y.
Ostatnia linijka wysyła to wszystko z buforu do gracza.
Odbieranie wiadomości
W paletce kontrolowanej przez przeciwnika, w evencie step umieszczamy kod:
kod:

var size;
while(true)
{
size = receivemessage(global.otherplayer);
if(size < 0) break;
if(size == 0)
{
show_message("The other player left the game");
game_end();
}
messageid = readbyte();
switch(messageid)
{
case 0:
y = readshort();
break;

case 1:
objBall.x = readshort();
objBall.y = readshort();:
break;
}
}

Pierwsza linijka tworzy nieskończoną pętlę while(true). Pierwsza linijka pętli odbiera wszystkie wiadomości od innego gracza i ustawia zmienną size na ilość bajtów odebranych. Druga linijka sprawdza czy aby na pewno odebraliśmy jakieś wiadomości. Jeśli nie to wychodzimy z tej pętli. Trzecia linijka sprawdza czy przeciwnik dalej gra. Jeśli wielkość wiadomości(zmienna size) jest równa 0 to gra nas informuje, że przeciwnik opuścił grę, a ta automatycznie się zamyka.
Jeżeli natomiast odebraliśmy jakąś wiadomość, musimy sprawdzić czego dotyczyła. Możemy użyć do tego skryptów bufora, w którym wszystkie dane się znajdują, po to, aby odebrać dane z wiadomości. Pierwsza część zwraca nam ID wiadomości. Po tym używamy deklaracji switch() aby co oznacza dane ID. Jeśli ID wynosi 0 to wiadomość oznacza pozycję Y przeciwnika. Pamiętaj, że używając konstrukcji short do wysłania jakiejś wiadomości to musimy użyć tej samej konstrukcji do odebrania wiadomości.
Jeżeli ID widomości wynosi 1 to wiemy, że dotyczy ona pozycji Y i X piłeczki. Używamy teraz konstrukcji short, aby odebrać pozycję X, analogicznie z pozycją Y.
CZYSZCZENIE DLLA
Jeśli nie chcesz żadnych nieprzyjemnych błędów, podczas zamykania gry, musisz oczyścić dlla z pamięci. Aby to zrobić tworzymy nowy obiekt i umieszczamy go w każdym roomie. W vencie Game End umieszczamy tylko jedną linijkę kodu :
dllfree();
Oczyści to całego WINSOCKa i pamięć używaną przez bufor wewnętrzny.
stron: 2

1

2

głosów: 7 | ocena: 7.42 oceń zasób | dodał: Mimek
Komentarze
stron: 312

3


av

kt1117 (22:31, 25.01.2011)

Jest jeszcze kilka literówek. Nie przeszkadzają specjalnie, ale są np. dunkcja.

av

Mentoss (6:30, 8.04.2011)

da się jakoś później w TCP wylączyc socketa ?

av

Tymon (11:19, 8.04.2011)

closesocket?

av

Ma?ko (15:50, 6.07.2012)

Bardzo dobry dll to robienia multiplayerów.

stron: 312

3



Dodaj komentarz:
Treść:
Menu
Panel użytkownika
Jesteś niezalogowany!

Nie masz konta? Zarejestruj się
Użytkownicy on-line
1 użytkownik(ów) aktywny(ch) przez ostatnie 15 minut:
gości: 1, userów: 0, ukrytych: 0
Użytkownicy na czacie discord
I am Lord (22:51, 24.11.17):
Byłem kucem ale teraz jestem skrytym kucem
Wojo (22:38, 24.11.17):
Jak coś to nie do ciebie Huder
Wojo (22:37, 24.11.17):
Od kiedy polityka znów pojawiła się na gmclanie? Myślałem, że zbuntowane polityczne kuce już wyginęły P
I am Lord (22:07, 24.11.17):
Wyczuwam z tego doskonałe memy z "deal with it" www.pudelek.pl/...tlas_kotow_foto
hgter (1:05, 24.11.17):
Już sobie na wszelki wypadek przeniosłem jedną do steama taką razem z androidem. Ale wiele modułów, których licencje mam na mailu nie ma klucza steamowego. No nic pewnie przy formacie po prostu wezmę licencję yoyo z maila. Chyba, że to wyłączą. Ale nie spodziewam się. Nikt by im po czymś takim z 2.0 nie zaufał.
Ignatus (11:32, 23.11.17):
Chyba jedyna opcja przy formacie kompa to wersja steam?
gnysek (11:07, 23.11.17):
O kurde, zlikwidowali to... no to nie wiem, pewnie przyznaje każdą którą znajdzie
gnysek (11:03, 23.11.17):
licencje wybierasz chyba na stronie YYG
hgter (23:35, 22.11.17):
gnysek: Ok, dzięki. Tylko to ma zastosowanie też do 1.4? Bo ja mam kilka licencji z różnymi podpiętymi modułami. Ciekawe jak wybiera odpowiednią. No nic w razie czego mam spis na maila. Dopóki nie wyłączą serwerów powinno być ok.
PsichiX (21:53, 22.11.17):
imprezy firmowe w srode to nie jest trzezwy pomysl xD
gnysek (9:50, 22.11.17):
a jak coś dokupisz, to musisz raz jeszcze wpisać login i hasło w menu help > upgrade i zrobić restart
gnysek (9:50, 22.11.17):
teraz chyba tylko mejla podajesz i hasło, nie ma kodów
hgter (16:47, 21.11.17):
W PRODUCTS da się przełączyć na 1.4, alr tam jest spis wszystkiego co kupiłem, ale bez kodów. Jak się dobrać do kodów? Kiedyś było chyba coś takiego jako Recovery i na maila słali, ale tego też nie mogę znaleźć.
hgter (16:36, 21.11.17):
Chciałem sprawdzić jak to było z tym linuxe i zalogowałem się na moje konto w yoyo. Gdzie teraz są tam numery licencji? Bo szukam i szukam i nigdzie nie ma podsumowania ze spisem posiadanych modułów wraz z kodami. Kiedyś była ładna tabelka.
TO_mek (14:20, 21.11.17):
GMS 1.4 ma eksport do linuxa?
gnysek (12:38, 21.11.17):
W sumie powinienem napisać że słaba.
gnysek (10:51, 21.11.17):
Pełną + moduł. Dlatego napisałem, że oferta średnia.
hgter (0:56, 21.11.17):
Odnosząc się do ogłoszenie gnyska o subscypcji za $39: Tylko jak w tej wersji w "subskrypcji" można rozwiązać moduł na androida? Da się coś taniej? Muszę kupić moduł za 1450 zł? Czy też w tej wersji nie da się z niego skorzystać i muszę kupić pełną+moduł czyli dać 1800 zł?
PsichiX (17:42, 20.11.17):
mieli DLC pod tytulem "kompilacja do kodu natywnego", a biedaki cebulaki meczyc sie z powolnym gmlem xD
Wojo (16:09, 20.11.17):
może jeszcze dlc przyspieszające ładowanie gier?
Wojo (16:08, 20.11.17):
hahaha ten news o nowym gmie pokazuje jak jego poziom upadł na ryj
gnysek (9:37, 20.11.17):
Po prostu każdy sterownik inaczej interpretuje polecenia rysowania linii z directx i ogólnie nikt tego już nie używa w profesjonalnych grach.
gnysek (9:36, 20.11.17):
To nie wina gma tylko kart graficznych. I chyba nawet w dokumentacji jest to opisane czemu tak działa i że własnie lepiej rysować sprite.
hgter (21:40, 19.11.17):
Miałem napisać długi post o skopaniu draw_line w Gm. Ale to nie ma sensu (cyrki jakie w tym wychodzą są nieziemskie). Draw_line nie działa w Gm (działało nawet kurde qbasicu pod dosem) a już pod androidem to co się wyprawia to jakaś paranoja. Jak musisz mieć linię w swoim projekcie to narysuj ją sobie jako sprite.
Adriann (19:29, 19.11.17):
Hi hi
Saus (14:15, 18.11.17):
Siema śmieszki
hgter (10:42, 17.11.17):
Pozmieniałem wszystko na pliki i mam nadzieję, że będzie ok
hgter (10:41, 17.11.17):
Coś chyba nie jest do końca tak z dodawaniem grafik do postów. Wczoraj w nocy dodawałem screeny z gry przez linkowanie (zmieniałem ich wielkość przy pomocy narzędzi edycji w poście). Było wszystko ok, ale teraz jak zajrzałem to screeny wyparowały i tylko linki zostały. Natomiast jeden screen dodany jako plik był ok.
I am Lord (20:02, 16.11.17):
scroll byłby pokrętłem, może to wyglądać spoko
I am Lord (20:01, 16.11.17):
A zobacz w sumie bo nie sprawdzałem w jaki sposób są zrobione scrolle od myszek, tam też na pewno jest enkoder
I am Lord (20:01, 16.11.17):
ale no enkoder jednak fajniejsza sprawa bo nie ma ograniczenia obrotu
I am Lord (20:00, 16.11.17):
A na potencjometrach nie możesz?
Chell (19:13, 16.11.17):
knuje jakiś sprytny zegarek na rpi zero i tak mi zaswitalo ze takie pokrętło byłoby wygodnym inputem
I am Lord (19:08, 16.11.17):
A co konstruujesz?
I am Lord (19:08, 16.11.17):
A jak byś potrzebował liniowe enkodery to takie są np w drukarkach i skanerach
Chell (19:03, 16.11.17):
zawsze coś
I am Lord (18:59, 16.11.17):
w dodatku inkrementalne są tak jak chcesz ale wiesz jaka ich precyzja była
Chell (18:59, 16.11.17):
oo, super myśl, dzięki
I am Lord (18:58, 16.11.17):
skołuj sobie myszkę kulkową, tam są 2 takie enkodery obrotowe.
Chell (18:57, 16.11.17):
coś takiego ze starych komórek kojarzę, że jak normalny rotary encoder jest pionowy i nie da się go obracac jednym palcem tak mi chodzi o taki który jest płaski, wystaje z obudowy urządzenia tylko trochę z boku i można podkręcić
I am Lord (18:57, 16.11.17):
tzn budowa może być z tarczą wewnątrz enkodera a może być tak jak w starych kulkowych myszkach gdzie była tarcza na zewnątrz enkodera
Chell (18:55, 16.11.17):
jednak nie rysuje, lapek padl
I am Lord (18:54, 16.11.17):
no nie czaję o co ci chodzi z zatapianiem
Chell (18:54, 16.11.17):
już rysuje o co mi chodzi
I am Lord (18:53, 16.11.17):
ale to nadal liniowy tylko że się zwija
I am Lord (18:52, 16.11.17):
No to nie wiem, są jeszcze takie zwijane
Chell (18:51, 16.11.17):
bez max i min wartości w sensie
Chell (18:50, 16.11.17):
ale nie, bo wciąż zależy mi na samej czynności kręcenia, i żeby nie określał absolutnej wartości tylko inkrementowal i dekrementowal
Chell (18:50, 16.11.17):
masz refleks xD
I am Lord (18:48, 16.11.17):
encoder liniowy?
Ankieta
» Jakie kursy najchętniej widziałbyś na stronie ?
GM Studio
GM Studio 2
Godot
Construct

GMCLAN to serwis o programie Game Maker i nie tylko.
Copyright © 2002-2017. GMCLAN.ORG
Wszelkie prawa zastrzeżone. Kopiowanie materiałów bez zgody redakcji zabronione!
© 2002-2017 Ranmus (ranmus.pl), © 2017 {=|=} fable_inside();

[ Czas generowania strony: 0.57969 sekund ] [ Liczba zapytań MySQL: 13 ]