drd / dice-roll
Configurable roll of a dice
Installs: 4 890
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- php: >=7.3
- granam/integer: ^7.0
Requires (Dev)
- granam/exceptions-hierarchy: ^5.0
- granam/test-with-mockery: ^2.0
- mockery/mockery: ~1.2
- phpunit/phpunit: ~9.0
- roave/security-advisories: dev-master
README
Let's roll!
<?php use Granam\DiceRolls\Templates\Rollers\Roller1d6; use Granam\DiceRolls\Templates\Rollers\Roller2d6DrdPlus; $roller1d6 = new Roller1d6(); $rolledValue = $roller1d6->roll(); if ($rolledValue === 6) { echo 'Hurray! You win!'; } else { echo 'Try harder'; } $roller2d6Granam = new Roller2d6DrdPlus(); while (($roll = $roller2d6Granam->roll()) && $roll->getValue() <= 12) { echo 'Still no bonus :( ...'; } echo 'There it is! Bonus roll comes, with final value of ' . $roll->getValue() . ' Rolls were quite dramatic, consider by yourself: '; foreach ($roll->getDiceRolls() as $diceRoll) { echo 'Rolled number ' . $diceRoll->getRolledNumber() . ', evaluated as value ' . $diceRoll->getValue(); }
There are plenty of predefined templates of dices and rolls as 1d4, 1d6, 1d10.
You can mix those and any else you create by CustomDice
class.
Just think about your needs and check templates. Your requirements may be already satisfied by them.
Custom dices & rolls
There can be situations, where you need crazy combinations. Let's say one roll with 1d5 dice and three rolls with 1d74 dice.
It is easy. The hard part is only to find the way:
<?php use Granam\DiceRolls\Templates\Dices\CustomDice; use Granam\Integer\IntegerObject; use Granam\DiceRolls\Templates\Dices\Dices; use Granam\DiceRolls\Roller; use Granam\DiceRolls\Templates\Evaluators\OneToOneEvaluator; use Granam\DiceRolls\Templates\RollOn\NoRollOn; $dice1d5 = new CustomDice(new IntegerObject(1) /* minimum of the dice */, new IntegerObject(5) /* maximum of the dice */); $dice1d74 = new CustomDice(new IntegerObject(1) /* minimum of the dice */, new IntegerObject(74) /* maximum of the dice */); $diceCombo = new Dices([$dice1d5, $dice1d74, $dice1d74, $dice1d74]); $roller = new Roller( $diceCombo, new IntegerObject(1) /* roll with them all just once */, new OneToOneEvaluator() /* "what you roll is what you get" */, new NoRollOn() /* no bonus roll at all */, new NoRollOn() /* no malus roll at all */ ); // here it is! $roller->roll();
Install
- order composer to add new requirement
composer require drd/dice-roll