Merge pull request #507 from thecodingmachine/develop
Release 2020-12-18
This commit is contained in:
commit
cc805f5086
2
.github/workflows/build-and-deploy.yml
vendored
2
.github/workflows/build-and-deploy.yml
vendored
@ -167,7 +167,7 @@ jobs:
|
|||||||
- uses: rlespinasse/github-slug-action@3.1.0
|
- uses: rlespinasse/github-slug-action@3.1.0
|
||||||
|
|
||||||
- name: Deploy
|
- name: Deploy
|
||||||
uses: thecodingmachine/deeployer@master
|
uses: thecodingmachine/deeployer-action@master
|
||||||
env:
|
env:
|
||||||
KUBE_CONFIG_FILE: ${{ secrets.KUBE_CONFIG_FILE }}
|
KUBE_CONFIG_FILE: ${{ secrets.KUBE_CONFIG_FILE }}
|
||||||
ADMIN_API_TOKEN: ${{ secrets.ADMIN_API_TOKEN }}
|
ADMIN_API_TOKEN: ${{ secrets.ADMIN_API_TOKEN }}
|
||||||
|
1
front/src/Exception/TextureError.ts
Normal file
1
front/src/Exception/TextureError.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
export class TextureError extends Error{}
|
@ -3,6 +3,7 @@ import {SpeechBubble} from "./SpeechBubble";
|
|||||||
import BitmapText = Phaser.GameObjects.BitmapText;
|
import BitmapText = Phaser.GameObjects.BitmapText;
|
||||||
import Container = Phaser.GameObjects.Container;
|
import Container = Phaser.GameObjects.Container;
|
||||||
import Sprite = Phaser.GameObjects.Sprite;
|
import Sprite = Phaser.GameObjects.Sprite;
|
||||||
|
import {TextureError} from "../../Exception/TextureError";
|
||||||
|
|
||||||
export interface PlayerResourceDescriptionInterface {
|
export interface PlayerResourceDescriptionInterface {
|
||||||
name: string,
|
name: string,
|
||||||
@ -94,6 +95,9 @@ export abstract class Character extends Container {
|
|||||||
|
|
||||||
public addTextures(textures: string[], frame?: string | number): void {
|
public addTextures(textures: string[], frame?: string | number): void {
|
||||||
for (const texture of textures) {
|
for (const texture of textures) {
|
||||||
|
if(!this.scene.textures.exists(texture)){
|
||||||
|
throw new TextureError('texture not found');
|
||||||
|
}
|
||||||
const sprite = new Sprite(this.scene, 0, 0, texture, frame);
|
const sprite = new Sprite(this.scene, 0, 0, texture, frame);
|
||||||
sprite.setInteractive({useHandCursor: true});
|
sprite.setInteractive({useHandCursor: true});
|
||||||
this.add(sprite);
|
this.add(sprite);
|
||||||
@ -106,7 +110,9 @@ export abstract class Character extends Container {
|
|||||||
});
|
});
|
||||||
})
|
})
|
||||||
// Needed, otherwise, animations are not handled correctly.
|
// Needed, otherwise, animations are not handled correctly.
|
||||||
|
if(this.scene) {
|
||||||
this.scene.sys.updateList.add(sprite);
|
this.scene.sys.updateList.add(sprite);
|
||||||
|
}
|
||||||
this.sprites.set(texture, sprite);
|
this.sprites.set(texture, sprite);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -152,10 +158,7 @@ export abstract class Character extends Container {
|
|||||||
if (moving && (!sprite.anims.currentAnim || sprite.anims.currentAnim.key !== direction)) {
|
if (moving && (!sprite.anims.currentAnim || sprite.anims.currentAnim.key !== direction)) {
|
||||||
sprite.play(texture+'-'+direction, true);
|
sprite.play(texture+'-'+direction, true);
|
||||||
} else if (!moving) {
|
} else if (!moving) {
|
||||||
/*if (this.anims.currentAnim) {
|
sprite.anims.play(texture + '-' + direction, true);
|
||||||
this.anims.stop();
|
|
||||||
}*/
|
|
||||||
sprite.play(texture+'-'+direction, true);
|
|
||||||
sprite.anims.stop();
|
sprite.anims.stop();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -229,8 +232,10 @@ export abstract class Character extends Container {
|
|||||||
this.scene.events.removeListener('postupdate', this.postupdate.bind(this));
|
this.scene.events.removeListener('postupdate', this.postupdate.bind(this));
|
||||||
}
|
}
|
||||||
for (const sprite of this.sprites.values()) {
|
for (const sprite of this.sprites.values()) {
|
||||||
|
if(this.scene) {
|
||||||
this.scene.sys.updateList.remove(sprite);
|
this.scene.sys.updateList.remove(sprite);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
super.destroy(fromScene);
|
super.destroy(fromScene);
|
||||||
this.playerName.destroy();
|
this.playerName.destroy();
|
||||||
}
|
}
|
||||||
|
@ -63,6 +63,8 @@ import {urlManager} from "../../Url/UrlManager";
|
|||||||
import {PresentationModeIcon} from "../Components/PresentationModeIcon";
|
import {PresentationModeIcon} from "../Components/PresentationModeIcon";
|
||||||
import {ChatModeIcon} from "../Components/ChatModeIcon";
|
import {ChatModeIcon} from "../Components/ChatModeIcon";
|
||||||
import {OpenChatIcon, openChatIconName} from "../Components/OpenChatIcon";
|
import {OpenChatIcon, openChatIconName} from "../Components/OpenChatIcon";
|
||||||
|
import {SelectCharacterScene, SelectCharacterSceneName} from "../Login/SelectCharacterScene";
|
||||||
|
import {TextureError} from "../../Exception/TextureError";
|
||||||
|
|
||||||
export interface GameSceneInitInterface {
|
export interface GameSceneInitInterface {
|
||||||
initPosition: PointInterface|null,
|
initPosition: PointInterface|null,
|
||||||
@ -155,9 +157,9 @@ export class GameScene extends ResizableScene implements CenterListener {
|
|||||||
private playerName!: string;
|
private playerName!: string;
|
||||||
private characterLayers!: string[];
|
private characterLayers!: string[];
|
||||||
|
|
||||||
constructor(private room: Room, MapUrlFile: string) {
|
constructor(private room: Room, MapUrlFile: string, customKey?: string|undefined) {
|
||||||
super({
|
super({
|
||||||
key: room.id
|
key: customKey ?? room.id
|
||||||
});
|
});
|
||||||
this.Terrains = [];
|
this.Terrains = [];
|
||||||
this.groups = new Map<number, Sprite>();
|
this.groups = new Map<number, Sprite>();
|
||||||
@ -517,7 +519,7 @@ export class GameScene extends ResizableScene implements CenterListener {
|
|||||||
this.simplePeer.unregister();
|
this.simplePeer.unregister();
|
||||||
|
|
||||||
const gameSceneKey = 'somekey' + Math.round(Math.random() * 10000);
|
const gameSceneKey = 'somekey' + Math.round(Math.random() * 10000);
|
||||||
const game: Phaser.Scene = new GameScene(this.room, this.MapUrlFile);
|
const game: Phaser.Scene = new GameScene(this.room, this.MapUrlFile, gameSceneKey);
|
||||||
this.scene.add(gameSceneKey, game, true,
|
this.scene.add(gameSceneKey, game, true,
|
||||||
{
|
{
|
||||||
initPosition: {
|
initPosition: {
|
||||||
@ -580,7 +582,7 @@ export class GameScene extends ResizableScene implements CenterListener {
|
|||||||
|
|
||||||
|
|
||||||
this.scene.wake();
|
this.scene.wake();
|
||||||
this.scene.sleep(ReconnectingSceneName);
|
this.scene.stop(ReconnectingSceneName);
|
||||||
|
|
||||||
//init user position and play trigger to check layers properties
|
//init user position and play trigger to check layers properties
|
||||||
this.gameMap.setPosition(this.CurrentPlayer.x, this.CurrentPlayer.y);
|
this.gameMap.setPosition(this.CurrentPlayer.x, this.CurrentPlayer.y);
|
||||||
@ -670,9 +672,13 @@ export class GameScene extends ResizableScene implements CenterListener {
|
|||||||
|
|
||||||
public cleanupClosingScene(): void {
|
public cleanupClosingScene(): void {
|
||||||
// We are completely destroying the current scene to avoid using a half-backed instance when coming back to the same map.
|
// We are completely destroying the current scene to avoid using a half-backed instance when coming back to the same map.
|
||||||
|
if(this.connection) {
|
||||||
this.connection.closeConnection();
|
this.connection.closeConnection();
|
||||||
|
}
|
||||||
|
if(this.simplePeer) {
|
||||||
this.simplePeer.unregister();
|
this.simplePeer.unregister();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private switchLayoutMode(): void {
|
private switchLayoutMode(): void {
|
||||||
//if discussion is activated, this layout cannot be activated
|
//if discussion is activated, this layout cannot be activated
|
||||||
@ -818,6 +824,7 @@ export class GameScene extends ResizableScene implements CenterListener {
|
|||||||
createCurrentPlayer(){
|
createCurrentPlayer(){
|
||||||
//initialise player
|
//initialise player
|
||||||
//TODO create animation moving between exit and start
|
//TODO create animation moving between exit and start
|
||||||
|
try {
|
||||||
this.CurrentPlayer = new Player(
|
this.CurrentPlayer = new Player(
|
||||||
this,
|
this,
|
||||||
this.startX,
|
this.startX,
|
||||||
@ -828,6 +835,12 @@ export class GameScene extends ResizableScene implements CenterListener {
|
|||||||
false,
|
false,
|
||||||
this.userInputManager
|
this.userInputManager
|
||||||
);
|
);
|
||||||
|
}catch (err){
|
||||||
|
if(err instanceof TextureError) {
|
||||||
|
gameManager.leaveGame(this, SelectCharacterSceneName, new SelectCharacterScene());
|
||||||
|
}
|
||||||
|
throw err;
|
||||||
|
}
|
||||||
|
|
||||||
//create collision
|
//create collision
|
||||||
this.createCollisionWithPlayer();
|
this.createCollisionWithPlayer();
|
||||||
|
@ -126,10 +126,10 @@ export class CustomizeScene extends ResizableScene {
|
|||||||
gameManager.tryResumingGame(this, EnableCameraSceneName);
|
gameManager.tryResumingGame(this, EnableCameraSceneName);
|
||||||
});
|
});
|
||||||
|
|
||||||
this.input.keyboard.on('keydown-RIGHT', () => this.moveCursorHorizontally(1));
|
this.input.keyboard.on('keyup-RIGHT', () => this.moveCursorHorizontally(1));
|
||||||
this.input.keyboard.on('keydown-LEFT', () => this.moveCursorHorizontally(-1));
|
this.input.keyboard.on('keyup-LEFT', () => this.moveCursorHorizontally(-1));
|
||||||
this.input.keyboard.on('keydown-DOWN', () => this.moveCursorVertically(1));
|
this.input.keyboard.on('keyup-DOWN', () => this.moveCursorVertically(1));
|
||||||
this.input.keyboard.on('keydown-UP', () => this.moveCursorVertically(-1));
|
this.input.keyboard.on('keyup-UP', () => this.moveCursorVertically(-1));
|
||||||
|
|
||||||
const customCursorPosition = localUserStore.getCustomCursorPosition();
|
const customCursorPosition = localUserStore.getCustomCursorPosition();
|
||||||
if (customCursorPosition) {
|
if (customCursorPosition) {
|
||||||
|
File diff suppressed because one or more lines are too long
3
website/dist/create-map.html
vendored
3
website/dist/create-map.html
vendored
@ -109,6 +109,9 @@
|
|||||||
<li>set a start position for the players</li>
|
<li>set a start position for the players</li>
|
||||||
<li>configure the "floor layer" (so that WorkAdventure can correctly display characters above the floor, but under the ceiling)</li>
|
<li>configure the "floor layer" (so that WorkAdventure can correctly display characters above the floor, but under the ceiling)</li>
|
||||||
<li>eventually, you can place exits that link to other maps</li>
|
<li>eventually, you can place exits that link to other maps</li>
|
||||||
|
<li>the "Tile Layer Format" must be set to CSV. If you started from the map starter kit as explained above,
|
||||||
|
you have nothing to do. However, if you start from scratch, please be sure to select "CSV" for the tile layer format
|
||||||
|
when creating the map. You can change this setting later in the map properties.</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<h3 id="workadventure-maps-rules" class="pixel-title">WorkAdventure Map Rules</h3>
|
<h3 id="workadventure-maps-rules" class="pixel-title">WorkAdventure Map Rules</h3>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user