0

この行
g.setColor(new Color(numGen.nextInt(256), numGen.nextInt(256), numGen.nextInt(256)));
はランダムな色を生成しますが、何らかの理由で黒を含めたくありません。たとえば、値を 80 ~ 256 に制限して、暗い色を除外することはできますか。モジュロを試してみMath.randomましたが、うまくいきません。私を助けてください。どうもありがとうございました!

4

3 に答える 3

2

数値をオフセットしたい場合は、より小さな範囲でランダム化し、オフセットを追加します。

private int randomBetween(int min, int max) {
    int range = max - min;
    return min + numGen.nextInt(range);
}

...

g.setColor(new Color(randomBetween(80,256), randomBetween(80,256), randomBetween(80,256)));

これは、各色成分の最小強度が必要であると想定しています。

于 2012-10-11T04:08:00.830 に答える
1

80〜256の数値を生成するには:

css ..

table {
    font: 11px/24px Verdana, Arial, Helvetica, sans-serif;
    border-collapse: collapse;
    width: 320px;
    }

td {
    border: 1px solid #CCC;
    padding: 0 0.5em;
    }

html...。

<head>        
</head>
<body>
    <div id='mydiv'></div>
    <button id = "myRandomizeBtn">Randomize</button> 
</body>

javascript..。

$("#myRandomizeBtn").bind("click",randomizeHandler); 

function randomizeHandler(evt){     
var root=document.getElementById('mydiv');
var tab=document.createElement('table');
tab.className="mytable";
var tbo=document.createElement('tbody');
var row, cell;
var n = 3;  
var data;    

for (i=0; i<n; i++)
{
    row=document.createElement('tr');
    for(var j=0;j<n;j++){
        cell=document.createElement('td');
        data = Math.floor(80+(176*Math.random())); 
        cell.appendChild(document.createTextNode(data));
        row.appendChild(cell);
    }
    tbo.appendChild(row);
}
tab.appendChild(tbo);
root.appendChild(tab);
   }  

ここにjsfiddleへのリンクがあります...それが役立つことを願っています... http://jsfiddle.net/FhyHK/

于 2012-10-11T04:15:26.373 に答える
1
g.setColor(
  new Color(127 + numGen.nextInt(128), 
  new Color(127 + numGen.nextInt(128), 
  new Color(127 + numGen.nextInt(128));
于 2012-10-11T04:03:09.323 に答える