Closed GoogleCodeExporter closed 8 years ago
i think i nad similar problems with that block.
I changed the generated js code to this and it's worked for me:
Blockly.JavaScript['math_random_int'] = function(block) {
// Random integer between [X] and [Y].
var argument0 = Blockly.JavaScript.valueToCode(block, 'FROM',
Blockly.JavaScript.ORDER_COMMA) || '0';
var argument1 = Blockly.JavaScript.valueToCode(block, 'TO',
Blockly.JavaScript.ORDER_COMMA) || '0';
var code = 'Math.round(' + argument0 + ' + Math.random() * (' + argument1 + ' - ' + argument0 + '))';
return [code, Blockly.JavaScript.ORDER_FUNCTION_CALL];
};
Original comment by tvikto...@gmail.com
on 20 Oct 2013 at 6:18
Interesting. Thanks for the clear bug report. I have verified.
I suspect that the problem has to do with including the function that Blockly
uses for random_int. Viktor's code eliminates the need to include a function
but does not work if argument1 < argument0.
I've never touched the graph app so am going to pass this to Neil.
Original comment by sper...@google.com
on 21 Oct 2013 at 7:26
[deleted comment]
Sorry, but i must say, it is working both arg1>arg0 and arg0>arg1.
Example arg0=30 arg1=100 -> 30+random()*70 the result will be between 30 and 100
arg0=100 arg1=30 -> 100 + random()*(-70) -> 100 - random()*70 the result will
be between 100 and 30
Both are give the same range of rsult; as expected, the first case of the
result in ascendant row, the second in the descendant row.
Original comment by tvikto...@gmail.com
on 22 Oct 2013 at 2:26
http://blockly-demo.appspot.com/static/apps/graph/index.html#zhp4oe
I think code generation line should be slight changed:
var code = 'Math.round((' + argument0 + ') + Math.random() * ((' + argument1 +
') - (' + argument0 + ')))';
Original comment by bup...@google.com
on 22 Oct 2013 at 5:05
tviktor, I apologize. Your code does not depend on arg0 being less than arg1.
There is another issue, however. Using round() biases the function against a
result of arg0 or arg1, favoring values in between them. I believe the correct
function is:
Math.floor(math.min(argument0, argument1) + Math.random() * (Math.abs(argument1
- argument0) + 1))
bupjae, I do not believe the parentheses are necessary. The following line
will generate them if needed:
var argument0 = Blockly.JavaScript.valueToCode(block, 'FROM',
Blockly.JavaScript.ORDER_COMMA) || '0';
ORDER_COMMA means to parenthesize the code (if necessary) so it can't be broken
apart by a comma.
Original comment by sper...@google.com
on 22 Oct 2013 at 7:05
Correcting capitalization, that should be:
Math.floor(Math.min(argument0, argument1) + Math.random() * (Math.abs(argument1
- argument0) + 1))
Original comment by sper...@google.com
on 22 Oct 2013 at 7:11
tviktor, in the future, please share fixes with us so we can review and
incorporate them.
Original comment by sper...@google.com
on 22 Oct 2013 at 7:19
This issue was closed by revision r1458.
Original comment by neil.fra...@gmail.com
on 29 Oct 2013 at 9:20
Original issue reported on code.google.com by
bup...@google.com
on 15 Oct 2013 at 12:37