1
0
mirror of https://github.com/kkapsner/CanvasBlocker synced 2024-12-22 21:00:23 +01:00

Modified randomSuppies API

getRng now returns a 32 bit random Number
getIndexRng returns a random index in a range
getBitRng returns a random bit
getValueRng is the old getRng which alters the provided value
This commit is contained in:
kkapsner 2018-06-16 00:09:06 +02:00
parent e079e1c0a3
commit 032bc2e424
2 changed files with 141 additions and 108 deletions

View File

@ -124,7 +124,7 @@
var data2 = imageData2.data; var data2 = imageData2.data;
var l = data1.length; var l = data1.length;
if (l === data2.length){ if (l === data2.length){
var rng = randomSupply.getRng(l, window); var rng = randomSupply.getValueRng(l, window);
for (var i = 0; i < l; i += 1){ for (var i = 0; i < l; i += 1){
if (data1[i] > data2[i]){ if (data1[i] > data2[i]){
@ -314,7 +314,7 @@
object: "CanvasRenderingContext2D", object: "CanvasRenderingContext2D",
fakeGenerator: function(prefs, notify, window, original){ fakeGenerator: function(prefs, notify, window, original){
return function isPointInPath(x, y){ return function isPointInPath(x, y){
var rng = randomSupply.getRng(1, window); var rng = randomSupply.getValueRng(1, window);
var originalValue = original.apply(this, window.Array.from(arguments)); var originalValue = original.apply(this, window.Array.from(arguments));
if ((typeof originalValue) === "boolean"){ if ((typeof originalValue) === "boolean"){
notify.call(this, "fakedReadout"); notify.call(this, "fakedReadout");
@ -337,7 +337,7 @@
object: "CanvasRenderingContext2D", object: "CanvasRenderingContext2D",
fakeGenerator: function(prefs, notify, window, original){ fakeGenerator: function(prefs, notify, window, original){
return function isPointInStroke(x, y){ return function isPointInStroke(x, y){
var rng = randomSupply.getRng(1, window); var rng = randomSupply.getValueRng(1, window);
var originalValue = original.apply(this, window.Array.from(arguments)); var originalValue = original.apply(this, window.Array.from(arguments));
if ((typeof originalValue) === "boolean"){ if ((typeof originalValue) === "boolean"){
notify.call(this, "fakedReadout"); notify.call(this, "fakedReadout");

View File

@ -13,6 +13,56 @@
scope = window.scope.randomSupplies; scope = window.scope.randomSupplies;
} }
const rngTemplate = {
getBitRng: function(length, window){
const rng = this.getRng(Math.ceil(length / 32), window);
let bitIndex = 32;
let rnd = 0;
let mask = 0xffffffff * 2;
return function(value, i){
if (mask > 0xffffffff){
mask = 1;
rnd = rng(i / 32);
}
let bit = 1 * (!!(rnd & mask));
mask *= 2;
return bit;
};
},
getIndexRng: function(length, maxIndex, window){
const rng = this.getRng(length, window);
return function(i){
return Math.floor(rng(i) / 0xffffffff * maxIndex);
};
},
getValueRng: function(length, window){
const rng = this.getBitRng(length, window);
return function(value, i){
var rnd = rng(value, i);
// XOR the last bit to alter it... or not
return value ^ (rnd & 0x01);
};
},
getPixelRng: function(length, window, ignoredColors){
var rng = this.getValueRng(length, window);
return function(r, g, b, a, i){ // eslint-disable-line max-params
var index = String.fromCharCode(r, g, b, a);
if (ignoredColors[index]){
return [r, g, b, a];
}
var baseIndex = i * 4;
return [
rng(r, baseIndex + 0),
rng(g, baseIndex + 1),
rng(b, baseIndex + 2),
rng(a, baseIndex + 3)
];
};
}
};
const settings = require("./settings"); const settings = require("./settings");
function getDomain(window){ function getDomain(window){
@ -40,7 +90,7 @@
return typeof value === "number" && value >= 0 && value < 256; return typeof value === "number" && value >= 0 && value < 256;
}) })
){ ){
persistentRnd[domain] = value; persistentRnd[domain] = new Uint8Array(value);
} }
} }
} }
@ -73,12 +123,20 @@
return persistentRnd[domain]; return persistentRnd[domain];
}; };
}()); }());
scope.persistent = {
name: "persistent", scope.persistent = Object.create(rngTemplate);
setDomainRnd: function(domain, rnd){ scope.persistent.name = "persistent";
scope.persistent.setDomainRnd = function(domain, rnd){
persistentRnd[domain] = new Uint8Array(rnd); persistentRnd[domain] = new Uint8Array(rnd);
}, };
getRng: function(length, window){ scope.persistent.getRng = function(length, window){
var bitSet = new Uint32Array(getPersistentRnd(window).buffer);
var bitSetLength = bitSet.length;
return function(i){
return bitSet[i % bitSetLength];
};
};
scope.persistent.getBitRng = function(length, window){
var bitSet = getPersistentRnd(window); var bitSet = getPersistentRnd(window);
return function(value, i){ return function(value, i){
@ -93,37 +151,19 @@
// extract the bit // extract the bit
var bit = (bitSet[index] >>> bitIndex) & 0x01; var bit = (bitSet[index] >>> bitIndex) & 0x01;
// XOR the bit and the value to alter the last bit of it... or not return bit;
return value ^ bit;
}; };
},
getPixelRng: function(length, window, ignoredColors){
var rng = this.getRng(length, window);
return function(r, g, b, a, i){ // eslint-disable-line max-params
var index = String.fromCharCode(r, g, b, a);
if (ignoredColors[index]){
return [r, g, b, a];
}
var baseIndex = i * 4;
return [
rng(r, baseIndex + 0),
rng(g, baseIndex + 1),
rng(b, baseIndex + 2),
rng(a, baseIndex + 3)
];
};
}
}; };
scope.constant = { scope.constant = Object.create(rngTemplate);
name: "constant", scope.constant.name = "constant";
getRng: function(length, window){ scope.constant.getRng = function(length, window){
return scope.nonPersistent.getRng(length, window); return scope.nonPersistent.getRng(length, window);
}, };
getPixelRng: (function(){ scope.constant.getPixelRng = (function(){
var colors = Object.create(null); var colors = Object.create(null);
return function getConstantPixelRng(length, window, ignoredColors){ return function getConstantPixelRng(length, window, ignoredColors){
var rng = scope.nonPersistent.getRng(1024, window); var rng = scope.nonPersistent.getValueRng(1024, window);
return function(r, g, b, a, i){ // eslint-disable-line max-params return function(r, g, b, a, i){ // eslint-disable-line max-params
var index = String.fromCharCode(r, g, b, a); var index = String.fromCharCode(r, g, b, a);
@ -143,48 +183,28 @@
return color; return color;
}; };
}; };
}()) }());
};
scope.nonPersistent = { scope.nonPersistent = Object.create(rngTemplate);
name: "nonPersistent", scope.nonPersistent.name = "nonPersistent";
getRng: function(length, window){ scope.nonPersistent.getRng = function(length, window){
// Initialize the random number batch creation const maxLength = 0x4000;
var randomI = 65536; var randomI = maxLength;
var randomNumbers = new Uint8Array(Math.min(65536, length)); var randomNumbers = new Uint32Array(Math.min(maxLength, length));
return function(i){
return function(value, i){
if (randomI >= randomNumbers.length){ if (randomI >= randomNumbers.length){
// refill the random number bucket if empty // refill the random number bucket if empty
randomI = 0; randomI = 0;
if (length - i < 65536){ if (length - i < maxLength){
randomNumbers = new Uint8Array(length - i); randomNumbers = new Uint32Array(Math.max(1, length - i));
} }
window.crypto.getRandomValues(randomNumbers); window.crypto.getRandomValues(randomNumbers);
} }
var rnd = randomNumbers[randomI]; var rnd = randomNumbers[randomI];
randomI += 1; randomI += 1;
// XOR the last bit to alter it... or not return rnd;
return value ^ (rnd & 0x01);
}; };
},
getPixelRng: function(length, window, ignoredColors){
var rng = this.getRng(length, window);
return function(r, g, b, a, i){ // eslint-disable-line max-params
var index = String.fromCharCode(r, g, b, a);
if (ignoredColors[index]){
return [r, g, b, a];
}
var baseIndex = i * 4;
return [
rng(r, baseIndex + 0),
rng(g, baseIndex + 1),
rng(b, baseIndex + 2),
rng(a, baseIndex + 3)
];
};
}
}; };
scope.white = { scope.white = {
@ -194,6 +214,19 @@
return 255; return 255;
}; };
}, },
getBitRng: function(){
return function(){
return 1;
};
},
getIndex: function(){
return function(){
return 0;
};
},
getValueRng: function(){
return this.getRng();
},
getPixelRng: function(){ getPixelRng: function(){
return function(){ return function(){
return [255, 255, 255, 255]; return [255, 255, 255, 255];