java實現(xiàn)平面山脈模型
本文實例為大家分享了java實現(xiàn)平面山脈模型的具體代碼,供大家參考,具體內(nèi)容如下
核心方法:遞歸
其實當我第一次看到這個題目時,心中想的不就是個普通的遞歸嗎,直接取兩個點,然后不斷取橫坐標中點,然后中點縱坐標取隨機數(shù)不就行嗎,代碼如下
public void recur(Graphics g, double x1, double x2, double y1, double y2, int range) {
?? ??? ??? ?double x3 = (x1 + x2) / 2;
?? ??? ??? ?double y3 = (y1 + y2) / 2;
?? ??? ??? ?if (x2-x1<= 15) {
?? ??? ??? ??? ?g.drawLine((int) x1, (int) y1, (int) x3, (int) y3);
?? ??? ??? ??? ?g.drawLine((int) x2, (int) y2, (int) x3, (int) y3);
?? ??? ??? ??? ?return;
?? ??? ??? ?}
?? ??? ??? ?Random rand=new Random();
?? ??? ??? ?int num=rand.nextInt(range);
?? ??? ??? ?recur(g, x1, x3, y1, y3-num, range);
?? ??? ??? ?recur(g, x3, x2, y3-num, y2, range);?? ??? ??? ??? ??? ?
?? ??? ?}最終效果如下

很明顯這并不像山脈背景吧,然后我通過查閱相關資料了解到問題在于需要每次遞歸時需要將縱坐標隨機數(shù)值減小,改進后代碼如下
public void recur(Graphics g, double x1, double x2, double y1, double y2, int range) {
//range我用的是300,大家可以自己調節(jié)
?? ??? ??? ?double x3 = (x1 + x2) / 2;
?? ??? ??? ?double y3 = (y1 + y2) / 2;
?? ??? ??? ?if (x2-x1<= 1|range==0) {
?? ??? ??? ??? ?g.drawLine((int) x1, (int) y1, (int) x3, (int) y3);
?? ??? ??? ??? ?g.drawLine((int) x2, (int) y2, (int) x3, (int) y3);
?? ??? ??? ??? ?return;
?? ??? ??? ?}
?? ??? ??? ?Random rand=new Random();
?? ??? ??? ?int num=rand.nextInt(range*2)-range;
?? ??? ??? ?range*=0.5;
?? ??? ??? ?recur(g, x1, x3, y1, y3+num, range);
?? ??? ??? ?recur(g, x3, x2, y3+num, y2, range);?? ??? ??? ??? ??? ?
?? ??? ?}效果很接近山脈

然后我又想可以使用Polygon類來對山脈進行顏色填充,同時傳入不同的透明度進行不同山脈的區(qū)別一定更美觀,廢話不多說,上代碼
public void recur(Graphics g, double x1, double x2, double y1, double y2, int range,int alp) {
? ? ? ? //實例range用的是300
? ? ? ? //四座山脈透明度分別為220,180,120,40
?? ??? ?double x3 = (x1 + x2) / 2;
?? ??? ?double y3 = (y1 + y2) / 2;
?? ??? ?if (x2-x1<= 1|range==0) {
?? ??? ??? ?g.drawLine((int) x1, (int) y1, (int) x3, (int) y3);
?? ??? ??? ?g.drawLine((int) x2, (int) y2, (int) x3, (int) y3);
?? ??? ??? ?Polygon p=new Polygon();
?? ??? ??? ?p.addPoint((int)x3, (int)y3);
?? ??? ??? ?p.addPoint((int)x1, (int)y1);
?? ??? ??? ?p.addPoint((int)x1, 800);
?? ??? ??? ?p.addPoint((int)x2, 800);
?? ??? ??? ?p.addPoint((int)x2, (int)y2);
?? ??? ??? ?g.setColor(new Color(0,0,0,alp));
?? ??? ??? ?g.fillPolygon(p);
?? ??? ??? ?return;
?? ??? ?}
?? ??? ?Random rand=new Random();
?? ??? ?int num=rand.nextInt(range*2)-range;
?? ??? ?range*=0.5;
? ? ? ? //上面的0.5也可以改變,他控制的是循環(huán)次數(shù)和山脈的陡峭度,大家可以改變嘗試
?? ??? ?recur(g, x1, x3, y1, y3+num, range,alp);
?? ??? ?recur(g, x3, x2, y3+num, y2, range,alp);
?? ?}
大功告成
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
java使用common-fileupload實現(xiàn)文件上傳
這篇文章主要為大家詳細介紹了java使用common-fileupload實現(xiàn)文件上傳的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10
SpringCloud-Gateway轉發(fā)WebSocket失敗問題及解決
這篇文章主要介紹了SpringCloud-Gateway轉發(fā)WebSocket失敗問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-09-09
Eclipse下基于Java的OpenCV開發(fā)環(huán)境配置教程
這篇文章主要為大家詳細介紹了Eclipse下基于Java的OpenCV開發(fā)環(huán)境配置教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-07-07
深入理解JAVA中的聚集和組合的區(qū)別與聯(lián)系
下面小編就為大家?guī)硪黄钊肜斫釰AVA中的聚集和組合的區(qū)別與聯(lián)系。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考,一起跟隨小編過來看看吧2016-05-05

