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 -> Kursy GML
Treść artykułu
Tabela wyników na stronie
autor: Pental (30.12.08)
W tym artykule mam zamiar przedstawić, jak wykonać tabelę wyników, zwaną często high-score, bądź hi-score (wysokie punkty). Cała filozofia polega na tym, że tabela ta będzie znajdować się na twojej stronie, przesyłając dane w adresie. Aby było to bezpieczne, poruszymy także temat dotyczący zabezpieczenia otwieranej strony przed zmienianiem wartości w adresie. Wymagam więc od was kilku rzeczy: zarejestrowanej wersji Game Makera (bez niej się nie obejdzie w żaden sposób), niewielkiej, ale jednak jakiejś znajomości GMLa, średniej znajomości PHP, a co za tym idzie HTML i ew. CSS oraz implementacji MD5 w Game Makerze (autorstwa niejakiego Rithiura), którą znajdziesz w pobranym archiwum z przykładem. Jeśli nie spełniasz tych wymagań - niestety, nie zrozumiesz zagadnień omówionych w artykule, lub jeszcze gorzej - nie będziesz mógł takowej tabeli do swojej gry posiadać.

GML

Zacznijmy od kodu w GML. Zakładam, że pobrałeś już implementację MD5. Tak, dobrze myślicie, teraz czeka nas tłumaczenie, co to MD5. Otóż, istnieje coś takiego, jak skrót tekstu. Nazywamy go hashem. Hashe używane są do zabezpieczania danych. Jeśli znasz PHP na poziomie średnim, to wiesz, że istnieje metoda wysyłania danych GET. Jest ona o tyle niebezpieczna, że każdy może zmieniać wartości w linku strony. Tak samo jest z plikami ini. Jeśli ich nie szyfrujemy - każdy może pozmieniać wszelkie wartości. Szyfrować linków, niestety, nie da się, dlatego użyjemy też hasha. Hash może być, oczywiście, także skrótem pliku. Ale, nie zmieniając tematu - w naszym przypadku sprawa wygląda następująco:

Edytowanie wartości jest banalne, ale to już wiemy. Teraz, jak je zabezpieczyć? A co, gdyby złączyć te wszystkie wartości w jeden łańcuch, dodać jakieś hasło dla dodatkowego zabezpieczenia i zmienić to w hash? Hash można także wysłać w linku, a na stronie znowu łączymy przesłane dane i sprawdzamy czy hash z nich jest taki sam jak hash wysłany. Tak, takie rozwiązanie jest świetne. W tym artykule użyłem metody hashującej MD5. Używając jej, hash ma zawsze 16 znaków. Dzięki tej teorii, czeka nas już dwa razy mniej tłumaczenia :) . Skoro już wiesz, co to ten hash, możemy śmiało przejść do kodu w GML. Ponieważ nie mamy żadnej przykładowej gry, zróbmy losowanie punktów i po prostu podawanie nazwy i dodawania do tabeli. Wstaw taki kod w Create byle jakiego obiektu, który ma się znajdować w roomie:
gml:
site = 'localhost/hisco.../index.php';
password = 'PeNtAl';

score = round( random( 200 ) );
show_message( 'Ilosc twoich punktow to: ' + string( score ) );

var _t;

_t = show_message_ext( 'Czy chcesz dodac swoj wynik do tabeli najlepszych?',
'Tak', '', 'Nie' );
if ( _t < 3 )
{
nick = get_string( 'Podaj swoj nick:', 'Pental' );
hash = md5( nick + string( score ) + password );
execute_shell( site + '?add&nick=' + nick + '&score=' + string( score ) + '&code=' + hash, 0 );
}

show_message( 'Do widzenia :) !' );

Zmienna site to adres do pliku index.php na naszej stronie. W moim przypadku jest to localhost, ponieważ testowałem tabelę właśnie na lokalnej sieci. Oczywiście, zmień tą wartość na link do pliku wyświetlającego tabelę, np. www.mojastrona....bela/tabela.php . Dostrzec można także zmienną password - jest to ważne hasło, które musisz koniecznie zmienić. Dalej losujemy ilość punktów i ją wyświetlamy. Tworzymy tymczasową zmienną _t, po czym używając funkcji show_message_ext(), zadajemy pytanie, czy mamy dodać ten wynik na stronę. Jeśli _t nie wynosi 3, to znaczy, że wybraliśmy "tak" (ponieważ oprócz 3 jedyna możliwa opcja to pierwsza, bo druga jest pusta). A teraz najważniejsze - otworzenie strony. Najpierw pobieramy nick. Do zmiennej hash, która "mówi sama za siebie", przypisujemy skrót utworzony z połączenia nicka, punktów oraz hasła. Dalej uruchamiamy twoją stronę z odpowiednimi wartościami w tablicy GET.

Projekt strony

Tak, przyszedł czas na stronę. Zawsze, kiedy łączymy HTML (+ inne języki, które nie "predefiniują tekstu", np. CSS, JS, VB) z PHP, należy stworzyć projekt, układ strony (ang. design, layout), zaoszczędzisz w ten sposób wiele czasu. Ponieważ nie mowa tu o "najpiękniejszej tabeli", napisałem prosty, ale zawsze jakiś design tabeli. Cały kod to:
kod:
<html>
<head>
<style type="text/css">
table {
background-color: lightblue;
border: 1px solid blue;
}
td {
text-align: left;
border: 1px solid blue;
text-align: center;
font-family: Verdana;
font-size: 18px;
}
</style>
<title>Tabela najlepszych</title>
</head>
<body style="background-color: rgb( 200, 200, 255 );">
<center>
<font size="5">Tabela 10 najlepszych graczy.</font><br /><br />
<table width="500" cellspacing="1" cellpadding="1">
<tr style="color: red;"><td>Miejsce</td><td>Nazwa</td><td>Punkty</td></tr>
<tr><td>1.</td><td>Nick</td><td>punkty</td></tr>
<tr><td>2.</td><td>Nick</td><td>punkty</td></tr>
<tr><td>3.</td><td>Nick</td><td>punkty</td></tr>
<tr><td>4.</td><td>Nick</td><td>punkty</td></tr>
<tr><td>5.</td><td>Nick</td><td>punkty</td></tr>
<tr><td>6.</td><td>Nick</td><td>punkty</td></tr>
<tr><td>7.</td><td>Nick</td><td>punkty</td></tr>
<tr><td>8.</td><td>Nick</td><td>punkty</td></tr>
<tr><td>9.</td><td>Nick</td><td>punkty</td></tr>
<tr><td>10.</td><td>Nick</td><td>punkty</td></tr>
</table>
</center>
</body>
</html>

Wspomniałem już - taka tabela nie jest może ładna, ale na potrzeby przedstawienia naszego zagadnienia, tak więc nie należy narzekać. Jak widzimy - jeśli chodzi o HTML - zwykła tabelka, trzy razy znaczniki td w tr, oraz kilka atrybutów w znaczniku table.

Krok pierwszy: początek tabelki

Teraz usuńmy cały kod HTML od miejsca <table> (z <table> włącznie) do miejsca, gdzie napotkasz </table> (tak jak z <table>). Cały ten kod HTML zastąpimy kodem PHP, który oczywiście, jak wiemy, zwraca nam kod HTML. Pierwszym procesem będzie początek tabelki. Zacznijmy od:
kod:
<?php
// poczatek tabelki
echo '<table width="500" cellspacing="1" cellpadding="1">';
echo "<tr style="color: red;"><td>Miejsce</td><td>Nazwa</td><td>Punkty</td></tr>n";
?>

Tłumaczenie tego kodu nie ma sensu - po prostu wyświetlamy początek tabelki.

Krok drugi: parametry tabeli

Zawsze zaczynam wszystko od podania parametrów, czemu nie mielibyśmy tak zrobić i tym razem? Kontynuując:
kod:
// sciezka do wynikow (koniecznie do wymiany!)
$dir = 'wyniki';
// tajne haslo (koniecznie do wymiany!)
$pass = 'PeNtAl';
// maksymalna ilosc rekordow (najczesciej jest to 10)
$max = 10;
// nazwa pliku z wynikami (do wymiany)
$fname = 'wyniki.txt';
// wiadomosc
$text = '';

Tutaj także nie ma wiele do tłumaczenia, ponieważ komentarze mówią same za siebie. Zwróć uwagę na to, że tajne hasło musi być identyczne, jak poprzednio, w kodzie GML! Zmienna $text będzie przechowywać wiadomość, którą wyświetlimy na końcu, pod tabelką. $dir to folder, który musisz stworzyć obok pliku *.php, czyli za pewne index.php. Tam będziemy przechowywać wyniki w pliku o nazwie $fname (czyt. wyniki.txt). Nazwę tego folderu zmień, oczywiście analogicznie wartość zmiennej. Niektóre serwery blokują dostęp do plików w folderach, w których nie ma pliku index.* . Stwórz więc pusty plik index.html i wrzuć go do tego folderu. Nie twórz zaś w tym folderze pliku o nazwie "wyniki.txt"!

Krok trzeci: tworzenie pustej tabeli

Nasze dane o tabeli będziemy więc przechowywać w pliku w ten sposób:
kod:
punkty gracza z miejscem 1
nick gracza z miejscem 2
punkty gracza z miejscem 2
nick gracza z miejscem 3
punkty gracza z miejscem 3
nick gracza z miejscem 4
punkty gracza z miejscem 4
itd..

Tego pliku kazałem ci nie tworzyć, ponieważ po co masz go wypełniać, skoro może to zrobić nam PHP? Jeśli zobaczy, że nie ma pliku, to go tworzy i wypełnia tak:
kod:
nikt
0
nikt
0
nikt
0
nikt
0
itd..


Poza tym, później mamy pewność, że takowy plik istnieje i ma odpowiednie dane. Kolejny fragment kodu to:
kod:
// jesli plik z wynikami nie istnieje, tworzymy go i wypelniamy :)
$fname = $dir . '/' . $fname;
if ( !file_exists( $fname ) )
{
$file = fopen( $fname, 'w' );
for( $i = 0; $i < $max; $i++ )
fwrite( $file, "nniktn0" ); // cudzyslowy uzyte ze wzgledu na parser ''
fclose( $file );
}

Pierwsza linijka sprawia, że $fname nie zawiera już nazwy pliku, tylko ścieżki dostępu do niego (czyli nazwafolderu/nazwapliku). Teraz podczas używania tej zmiennej nie trzeba będzie łączyć jej z nazwą folderu i ukośnikiem, a jest to o wiele wygodniejsze i bardziej optymalne rozwiązanie. Zwróćmy uwagę na to, że użyłem cudzysłowów zamiast apostrofów. Parser apostrofów usuwa wszystkie znaki escape (n, t itd.), a to by nie pozwalało na przejście do nowej linii.

Krok czwarty: wczytanie tabeli

Nieważne, czy plik był, czy nie, teraz jest i możemy śmiało wczytać tabelę do dwóch tablic - $n[] dla nicków oraz $s[] dla punktów. A oto kod:
kod:
// wczytanie tabeli
file = fopen( $fname, 'r' );
fgets( $file );
for( $i = 0; !feof( $file ); $i++ )
{
$n[$i] = rtrim( fgets( $file ) );
$s[$i] = ( int )rtrim( fgets( $file ) );
}

Funkcja rtrim() usuwa znaki escape, a przecież takowy występuje w każdej linii (prócz ostatniej), jest to oczywiście znak nowej linii, czyli n. Dodatkowo używamy rzutowania z typu string do int, ponieważ ilość punktów to liczby, to oczywiste.

Krok piąty: dodawanie rekordu

Teraz najcięższy do zrozumienia i najdłuższy fragment kodu - dodawanie rekordu. Najpierw, sprawdzamy, czy istnieje tablica GET[ 'add' ] za pomocą funkcji isset(). Sama tablica nie ma żadnej wartości, aczkolwiek sugeruje nam, że mamy zamiar dodać rekord. Jeśli tak, przechodzimy dalej. Sprawdzamy za pomocą funkcji preg_match(), czy nick jest poprawny i nie zawiera znaków, które mogłyby tworzyć bałagan lub też znaków tworzących kod HTML. Jeśli nick jest niepoprawny - dajemy zmiennej $text odpowiednią wartość, abyśmy zostali o tym poinformowani. Jeśli nick jest poprawny, przechodzimy dalej. Teraz łączymy nick z ilością punktów (oczywiście należy dokonać konwersji z typu int do typu string) i naszym tajnym hasłem. Teraz cały ten łańcuch, który przechowuje zmienna $hash, zamieniamy w skrót tekstu, za pomocą wbudowanej w PHP funkcji MD5. Jeśli hash w tablicy GET[ 'code' ] jest równy powstałemu hashowi, znaczy to, że dane łącznie z hashem są poprawne, więc przechodzimy dalej. Dodatkowo sprawdzamy, czy nie istnieje plik o nazwie naszego hasha, ponieważ jeśli uda się dodać rekord, to takowy plik tworzymy. Jeśli ktoś chcę dodać kilak rekordów, wystarczy, że odświeży stronę. Aby to ominąć, właśnie tak postępujemy. Jeśli coś jest nie tak - zostajemy o tym poinformowani (zmiennej $text zmieniamy wartość), jeśli nie - przechodzimy dalej. Ostatnie "pytanie" brzmi następująco: Czy wynik jest większy niż zero i, czy jest lepszy chociaż niż najgorszy wynik? Jeżeli tak - przechodzimy dalej, czyli dodajemy wynik. Dodanie wyniku jest związane ze zmianą pozycji innych rekordów, posłuży nam do tego pętla krokowa for. Dodatkowo, zostajemy o tym poinformowani. Tworzy także plik o nazwie hasha. Taki kod nie powinien cię zdziwić:
kod:
// dodawanie rekordu
if ( isset( $_GET[ 'add' ] ) )
{
if ( preg_match( '/^[a-z0-9_#- ]+$/i', $_GET[ 'nick' ] ) != $_GET[ 'nick' ] )
{
// stworzenie hasha - w PHP mamy gotowa funkcje :)
$hash = $_GET[ 'nick' ] . $_GET[ 'score' ] . $pass;
$hash = md5( $hash );
if ( $hash == $_GET[ 'code' ] && !( file_exists( $dir . '/' . $hash ) ) )
{
// jesli hash jest poprawny, jestesmy tutaj :)
$sc = ( int )$_GET[ 'score' ];
if ( ( $sc ) && ( $sc > $s[$max - 1] ) )
{
// gratulacje, dostales sie do tabeli najlepszych :) !
$text = 'Gratulacje, ' . $_GET[ 'nick' ] . '. Twój wynik zostal dodany!';
fclose( fopen( $dir . '/' . $hash, 'w' ) );
for( $i = $max - 2; $i >= 0; $i-- )
{
if ( ( $s[$i] >= $sc ) || ( !$i && $sc >= $s[0] ) )
{
if ( ( $i ) || ( !$i && $sc <= $s[0] ) )
$i++;

for( $j = $max - 1; $j > $i; $j-- )
{
$s[$j] = $s[$j - 1];
$n[$j] = $n[$j - 1];
}

$s[$i] = $sc;
$n[$i] = $_GET[ 'nick' ];

break;
}
}
}
}
else
$text = 'Nie udalo się dodać wyniku!';
}
else
$text = 'Niepoprawny nick!';
}

Tak więc, nie ma już nawet czego tłumaczyć.

Krok ostatni: wyświetlanie informacji i koniec tabeli

Pozostało nam już tylko wyświetlić tabelę oraz informację i zakończyć tabelę. Jeśli dotychczas wszystko zrozumiałeś, zrozumiesz także i ten kod:
kod:
// wyswietlanie tabeli
for( $i = 0; $i < $max; $i++ )
{
echo '<tr><td>' . ( string )( $i + 1 ) . '.</td><td>';
echo $n[$i] . '</td><td>';
echo ( string )$s[$i] . "</td></tr>n";
}

// zapis
$out = "";
for( $i = 0; $i < $max; $i++ )
$out .= "n" . $n[$i] . "n" . ( string )$s[$i];
file_put_contents( $fname, $out );

// wiadomosc :)
echo '</table><br/><b><font size="2">' . $text . '</font></b>';
?>

Wyświetlamy zawartości tablic, należy jednak pamiętać o konwersji tablicy przechowującej ilości punktów do łańcucha (string). Należy przyjrzeć się jeszcze zapisowi. Do zmiennej $out przypisujemy wartości tablic i nowe znaki, po czym nadpisujemy plik funkcją file_put_contents(). Podczas wyświetlania końca tabeli wyświetlamy także niżej wiadomość.

Jeśli robiłeś wszystko zgodnie z tym artykułem - właśnie udało ci się stworzyć tabelę wyników do swojej gry :) ! Oczywiście, uczyń ją ładniejszą i zmień parametry według własnego uznania.

Na koniec chciałem podziękować Tymonowi, współtwórcy tego artykułu, za dokładne wytłumaczenie, co to hash ;).

Przykład do ściągnięcia (w tym przykład, jak powinna wyglądać twoja strona): gmclan.org/up42...ajlepszych.html
Strona autora implementacji MD5 w Game Makerze: rithiur.anthd.c...gm/libs/md5.php

Przykładowa strona z takową tabelą (aby testować, wystarczy w pliku gm6 zmienić wartość zmiennej site na ten właśnie link): mental.ugu.pl/hiscore
głosów: 9 | ocena: 7.88 oceń zasób | dodał: Maximal
Komentarze
stron: 21

2


av

Ghost (9:28, 27.02.2009)

A u mnie pisze "Trwa ładowanie strony" i nic więcej xD A wszystko robię jak należy ;/

av

Pental Stary (15:20, 27.02.2009)

Rozumiem Adamie, że jesteś debilem i uważasz to za swój życiowy sukces? Poziom twoich programów żeby był tak wysoki jak twoja wiedza o informatyce, byłoby miło. A ty pewnie nawet nie wiesz, co to MD5 xD .

av

47xxxxxxxx (11:29, 11.06.2009)

gmclan.org/uplo...entalh4cker.png to się pokazuje kiedy wciskam link mental.ugu.pl/****ore (ocenzurowałem żeby jakiś n00b nie kliknął jeszcze raz)

av

Ghost (12:54, 11.06.2009)

Trojan.Clicker - coś jak okienka pop-up, idź się powieś, ale najpierw pomyśl i przeczytaj treść tego wirusa -.-

av

Roki (12:57, 11.06.2009)

A mi nie działa Ciągle pisze trwa ładowanie strony :/
Ale jakoś sobie poradze, tylko czy ktoś mi może polecić dobry, darmowy hosting?

av

gnysek (14:38, 11.06.2009)

Tak. Na własnym PC.

av

Ghost (14:54, 11.06.2009)

gnysek, zamknij dziobek. www.ic.cz

av

Roki (15:04, 11.06.2009)

Aha, racja to przez yoyo.pl :/

av

bluks (10:40, 28.07.2009)

yoyo.pl Nie istnieje idoto.

av

KozakPL (11:58, 29.07.2009)

od kiedy? lol

av

bluks (13:13, 29.07.2009)

A jedak. Sory ale jak wklejałem wcześniej to mi pokazało że nie ma takiej strony.

av

Egzekutor (9:28, 30.07.2009)

bluks: ale wtopa

av

pivot18 (14:09, 24.11.2009)

bluks: O lol
A przykład fajny :>

av

Bassmaster (18:05, 17.02.2010)

Wyczerpujący, nareszcie! Znalazłem to co potrzebowałem 10 pkt

av

Piotrek1910 (15:09, 18.12.2011)

Mi to nie działa proszę pho.ugu.pl/tabela/index.php a pobrałem przykład

stron: 21

2



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

Nie masz konta? Zarejestruj się
Użytkownicy on-line
5 użytkownik(ów) aktywny(ch) przez ostatnie 15 minut:
gości: 4, userów: 1, ukrytych: 0
I am vader
Użytkownicy na czacie discord
I am vader (12:50, 18.08.18):
gratki
Penguin (11:29, 18.08.18):
Gratulacje
exp (22:07, 17.08.18):
gratuluję również, kariera z przyszłością
Chell (15:00, 17.08.18):
dzieki
Wojo (11:37, 17.08.18):
Gratulacje
Chell (7:00, 17.08.18):
jaką stawkę myślicie że mogę wołać ako junior php po miesiącu praktyk i 2 stażu?
Chell (6:59, 17.08.18):
gmclany, zaraz będę kończył staż i zaczynał pracę na pół etatu
gnysek (9:54, 16.08.18):
niewiele, ale jest szybsze.
MaxGaming (3:25, 16.08.18):
Skoro pliki o rozszerzeniu html(przy standardowej konfiguracji serwera) są po prostu wyświetlane, a te z rozszerzeniem php wykonywane to czy użycie pliku html o tym samym kodzie jest szybsze niż pliku php(jeśli w źródle pliku znajduje się oczywiście sam kod hrml)?
Wojo (17:12, 15.08.18):
Exp podglądaj sobie reportaże o chwilowkach i o tym jak ludzie mają problemy z wyjaśnieniem że nie brali żadnego kredytu
exp (15:16, 15.08.18):
max czemu nie mógł udowodnić, nie chcieli sprawdzić jego podpisu? numer dowodu się zgadzał?
exp (15:15, 15.08.18):
no to też może się przydać, bo typ na koncie google miał podane imię i nazwisko i w adresie prawdopodobnie miał datę urodzenia, więc jak ktoś mnie okradnie, to mam podejrzanego. ale wątpię, że prokuratura będzie zainteresowana tym
I am vader (12:27, 15.08.18):
Nie powinno też się mordować ale to nie powstrzymuje ludzi
Wojo (22:26, 14.08.18):
Ale z drugiej strony nie powinno się kogoś okradać mimo wszystko
Sutikku (21:57, 14.08.18):
exp w formie dowodu mógłby pokazać, że nieumyślnie wysłał komuś swoje dane?
MaxGaming (17:37, 14.08.18):
Mój znajomy własnie wpadł w taką chwilówkę i jako że nie potrafił udowdnić że to nie on wziął to musi to spłacać
exp (17:36, 14.08.18):
no jak czytałem o tym, to w takiej sytuacji musisz de facto udowodnić niewinność
Wojo (19:56, 13.08.18):
z tym są różne scenariusze ale i tak powinien ktoś to uregulować bo to jest nienormalne jak mozna czlowiekowi zniszczyc zycie przez bledy mlodosci
exp (19:46, 13.08.18):
zna mój adres zameldowania, a nie zamieszkania, więc wyjebongo. boję się tylko o chwilówki itd. podobno w razie przyjścia komornika łatwo zamknąć sprawę, ale i tak nie chciałbym takich nieprzyjemności
Sutikku (19:29, 13.08.18):
osobiście myślę, że nic Ci nie grozi, ewentualnie pizza co wieczór będzie przyjeżdżać
exp (15:33, 13.08.18):
przez głupią literówkę wysłałem skan pewnego papieru niewłaściwej osobie. robię to regularnie i zrobiłem się trochę nieostrożny
exp (15:31, 13.08.18):
myślicie, że grozi mi coś, jeśli obcy człowiek posiadł prawie wszystkie moje dane osobowe? (ale nie zna mojego numeru dowodu)
gnysek (10:20, 11.08.18):
Dobra zrestartowałem serwer.
gnysek (10:36, 10.08.18):
wynajem!
MaxGaming (0:23, 10.08.18):
chodiz mi bardziej o doświadczenie niż hajs bo pracować wolę na swoim za mniej niż na etacie za więcej ale jednak pierwsza praca po technikum informatycznym od razu w marketingu to fajna sprawa. Tylko jeździć ponad 100km w jedną stronę codziennie pociągiem?
MaxGaming (0:22, 10.08.18):
więc nie mam pojęcia co robić
MaxGaming (0:22, 10.08.18):
wgl to zaproponowano mi prace w dziale marketingu jednej z polskich firm dzięki temu co uczę się na własną rekę, sam dyrektor działu marketingu stwierdził że woli takie osoby niż te świeżo po studiach które na studiach nie nauczą się praktycznie nic co jest na prawdę potrzebne w tej pracy ale... w WWA a ja mam jednak daleko żeby codziennie tam dojedżać
MaxGaming (23:56, 9.08.18):
nie wytłumaczysz że na prawdę rząd nie może stworzyć tych pieniędzy na 500 plus
MaxGaming (23:55, 9.08.18):
Obsługi telefonu dziecko się samo potrafi nauczyć. Teraz spróbuj nauczyć tego moją babcię. Zrozumcie że ludzie są różni. Znam 20 latków których
I am Lord (23:13, 9.08.18):
I nie chodził na żadne dokształcające najęcia
I am Lord (23:13, 9.08.18):
Mój tata pojechał do Norwegii bez języka i się nauczył go w rok już tak że coś tam rozumiał w pracy a przez 3 latach już w miarę płynnie gada
I am Lord (23:11, 9.08.18):
Przebywanie w obcym środowisku dłuższy czas sam w sobie uczy człowieka jezyka
Sutikku (22:46, 9.08.18):
zgadzam się
MaxGaming (22:40, 9.08.18):
Ale język nie jest potrzebny żeby przetrwać widocznie. Odpuścice trochę. Każda rozsądna osoba by się uczyła języka ale nie jest to jakiś przymus. Myślę że to właśnie dzięki temu że takie osoby nie myślą "nie znasz języka, nie próbuj" to przynajmniej nie siedzą na zasiłkach w Polsce tylko na zmywaku w Anglii
Sutikku (22:36, 9.08.18):
o przepraszam za przekleństwa, wydawały się tak adekwatne do treści, ze nie zauważyłem.
Sutikku (22:34, 9.08.18):
a co to za robienie gierek jak wychodzą Ci chujowe i są rakiem gamingu, i co z Ciebie za żołnierz jak chujowo strzelasz? Grunt, że próbują, efekty słabe fakt. Nie uważam, że to dobre i mądre wyjście, nie miałbym strefy komfortu gdybym nie mógł komunikować się w czyimś kraju, ale potrafię takich ludzi zrozumieć. Dziwniejsze jest dla mnie, że będąc tak długo w danym kraju język sam się nie podłapie.
Wojo (21:20, 9.08.18):
najwyraźniej nie jesteś patustem skoro nie potrafisz pojąć tego jak można żyć na krawędzi i bez żadnych zmartwień
I am vader (20:11, 9.08.18):
Ale co to za życie jak się izolujesz i stajesz się rakiem narodu?
Sutikku (17:40, 9.08.18):
potrafią i próbują ;p
Sutikku (17:40, 9.08.18):
słabe porównania, bo za granicę przeważnie jedzie się zarobić i żyć, a skoro oni zarabiają i żyją, to więcej im do szczęścia nie trzeba
I am vader (17:20, 9.08.18):
Jak idziesz na wojnę uczysz się strzelać, bo inaczej zginiesz. Jak chcesz zrobić grę to uczysz się programowania, bo inaczej nie dasz rady. Jak idziesz do szkoły uczysz się tego co Ci każą, bo inaczej jesteś idiotą. Jak wyjeżdżasz za granicę, uczysz się jezyka i kultury, bo inaczej jesteś pasożytem. Proste. Nie potrafisz, nie próbuj.
Wojo (14:32, 9.08.18):
Zazwyczaj są to ludzie, którzy nie lubią gdy narzuca im się jakiekolwiek zasady
exp (13:44, 9.08.18):
max, jeżeli nauczenie się języka kraju, w którym mieszka się na stałe jest dla niektórych niemożliwe ze względu na "strefę komfortu" to już nie wiem, co mam powiedzieć xd
exp (13:43, 9.08.18):
też znam ukraińców, którzy mówią po polsku, niektórzy bardzo dobrze. tak samo, jak wielu polaków w anglii czy niemczech też dobrze zna język miejscowy. nigdzie nie mówiłem, że wszyscy są źli, ale wielu
Wojo (13:15, 9.08.18):
propaganda cały czas istnieje tylko jest bardziej lub mniej intensywna. Aktualnie nie ma żadnej szansy aby dziecko nie było skażone propagandą (no chyba, że mieszka w jaskini)
MaxGaming (12:14, 9.08.18):
nie słuchałem jak ktoś kiedyś na tym forum polecał w każdym nowym telefonie taśmą zaklejać ten czujnik zalania i teraz mam problem XD
MaxGaming (12:09, 9.08.18):
za dużo propagandy już poszło. Trzeba by czekać a nowe pokolenie które nie jest skażone propagandą A o zgrozo propaganda nie ustaje
MaxGaming (12:08, 9.08.18):
W sumie demokracja to jedna wielka pułapka. Co możemy niby zrobić? Chodzić po domach i tłumaczyć ludziom żeby głosować na inne partie? Nie da rady przekonać większości
MaxGaming (12:07, 9.08.18):
sądzą że są sprytni bo wolą PO albo PiS, a to jest jeden ciort
MaxGaming (12:07, 9.08.18):
Ale tak jest w obie strpny. "Wpjna" PO/PiS to pułapka w którą większośc ludzi się łapie
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.
[ Polityka prywatności ]
Copyright © 2002-2018. GMCLAN.ORG
Wszelkie prawa zastrzeżone. Kopiowanie materiałów bez zgody redakcji zabronione!
© 2002-2017 Ranmus (ranmus.pl), © 2017-2018 {=|=} fable_inside();

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