PocketMine-MP
5.23.3 git-f7687af337d001ddbcc47b8e773f014a33faa662
Loading...
Searching...
No Matches
XpLevelUpSound.php
1
<?php
2
3
/*
4
*
5
* ____ _ _ __ __ _ __ __ ____
6
* | _ \ ___ ___| | _____| |_| \/ (_)_ __ ___ | \/ | _ \
7
* | |_) / _ \ / __| |/ / _ \ __| |\/| | | '_ \ / _ \_____| |\/| | |_) |
8
* | __/ (_) | (__| < __/ |_| | | | | | | | __/_____| | | | __/
9
* |_| \___/ \___|_|\_\___|\__|_| |_|_|_| |_|\___| |_| |_|_|
10
*
11
* This program is free software: you can redistribute it and/or modify
12
* it under the terms of the GNU Lesser General Public License as published by
13
* the Free Software Foundation, either version 3 of the License, or
14
* (at your option) any later version.
15
*
16
* @author PocketMine Team
17
* @link http://www.pocketmine.net/
18
*
19
*
20
*/
21
22
declare(strict_types=1);
23
24
namespace
pocketmine\world\sound;
25
26
use
pocketmine\math\Vector3
;
27
use
pocketmine\network\mcpe\protocol\LevelSoundEventPacket
;
28
use
pocketmine\network\mcpe\protocol\types\LevelSoundEvent
;
29
use
function
intdiv;
30
use
function
min;
31
32
class
XpLevelUpSound
implements
Sound
{
33
public
function
__construct(
private
int
$xpLevel){}
34
35
public
function
getXpLevel() :
int
{
36
return
$this->xpLevel;
37
}
38
39
public
function
encode
(
Vector3
$pos) : array{
40
//No idea why such odd numbers, but this works...
41
//TODO: check arbitrary volume
42
return [
LevelSoundEventPacket
::nonActorSound(
LevelSoundEvent
::LEVELUP, $pos, false, 0x10000000 * intdiv(min(30, $this->xpLevel), 5))];
43
}
44
}
pocketmine\math\Vector3
Definition
Vector3.php:36
pocketmine\network\mcpe\protocol\LevelSoundEventPacket
Definition
LevelSoundEventPacket.php:21
pocketmine\network\mcpe\protocol\types\LevelSoundEvent
Definition
LevelSoundEvent.php:21
pocketmine\world\sound\XpLevelUpSound
Definition
XpLevelUpSound.php:32
pocketmine\world\sound\XpLevelUpSound\encode
encode(Vector3 $pos)
Definition
XpLevelUpSound.php:39
pocketmine\world\sound\Sound
Definition
Sound.php:29
src
world
sound
XpLevelUpSound.php
Generated by
1.12.0