c語(yǔ)言打印貝塞爾曲線坐標(biāo)(三階)

貝塞爾曲線

貝塞爾曲線(Bézier curve),是應(yīng)用于二維圖形應(yīng)用程序的數(shù)學(xué)曲線。一般的矢量圖形軟件通過(guò)它來(lái)精確畫出曲線,貝賽爾曲線由線段節(jié)點(diǎn)組成握爷,節(jié)點(diǎn)是可拖動(dòng)的支點(diǎn)锌蓄,線段像可伸縮的皮筋,我們?cè)诶L圖工具上看到的鋼筆工具就是來(lái)做這種矢量曲線的瓜晤。貝塞爾曲線是計(jì)算機(jī)圖形學(xué)中相當(dāng)重要的參數(shù)曲線,在一些比較成熟的位圖軟件中也有貝塞爾曲線工具,如PhotoShop等浦旱,模擬鼠標(biāo)移動(dòng)軌跡過(guò)驗(yàn)證碼的時(shí)候也會(huì)用到。


屁話不多說(shuō) 直接上代碼鴨九杂!

控制點(diǎn)控制曲線

#include<stdio.h>

typedef struct Point

{

? ? int x;

? ? int y;

}Point;

int main()

{

? ? Point p0, p1, p2, p3 ,pot;//起始點(diǎn) 控制點(diǎn)1 控制點(diǎn)2 終止點(diǎn)3 繪制點(diǎn)

? ? float k,b;//斜率 和 截距

? ? p0.x = 100;//比如這是起始點(diǎn)x

? ? p0.y = 400;//比如這是起始點(diǎn)y

? ? p1.x = 100;//控制點(diǎn)坐標(biāo)可以隨便整數(shù)

? ? p1.y = 800;//控制點(diǎn)坐標(biāo)可以隨便整數(shù)

? ? p2.x = 800;//控制點(diǎn)坐標(biāo)可以隨便整數(shù)

? ? p2.y = 100;//控制點(diǎn)坐標(biāo)可以隨便整數(shù)

? ? p3.x = 1100;//比如這是起終點(diǎn)x

? ? p3.y = 600;//比如這是起終點(diǎn)y

? ? printf("打印控制點(diǎn)坐標(biāo)p1=%d,%d? ? p2=%d,%d\n",p1.x,p1.y,p2.x,p2.y);

? ? float? t = 0.01;//曲線參數(shù)t

? ? float temp = 1 - t;

? ? printf("輸出軌跡\nx = [");

? ? for(t=0;t<1;t+=0.01)

? ? {

? ? ? ? temp = 1 - t;

? ? ? ? pot.x = p0.x * temp * temp * temp + 3 * p1.x * t * temp * temp + 3 * p2.x * t * t * temp + p3.x * t * t * t;

? ? ? ? printf("%d,",pot.x);

? ? }

? ? printf("]\ny = [");

? ? for(t=0;t<1;t+=0.01)

? ? {

? ? ? ? temp = 1 - t;

? ? ? ? pot.y = p0.y * temp * temp * temp + 3 * p1.y * t * temp * temp + 3 * p2.y * t * t * temp + p3.y * t * t * t;

? ? ? ? printf("%d,",pot.y);

? ? }

? ? printf("]\n");

? ? return 0;

}



還有模擬鼠標(biāo)行為的軌跡代碼 每次坐標(biāo)會(huì)不一樣

/*

? ? 模擬鼠標(biāo)移動(dòng)軌跡

*/

#include<stdio.h>/

#include<stdlib.h>

#include<time.h>

typedef struct Point

{

? ? int x;

? ? int y;

}Point;

int main()

{

? ? srand(time(NULL));

? ? Point p0, p1, p2, p3 ,pot;//起始點(diǎn) 控制點(diǎn)1 控制點(diǎn)2 終止點(diǎn)3 繪制點(diǎn)

? ? float k,b;//斜率 和 截距

? ? p0.x = 100;//比如這是起始點(diǎn)x

? ? p0.y = 400;//比如這是起始點(diǎn)y

? ? p1.x = rand()%1399;//控制點(diǎn)坐標(biāo)可以隨便整數(shù)

? ? p1.y = -1;//控制點(diǎn)坐標(biāo)可以隨便整數(shù)

? ? p2.x = rand()%1399;//控制點(diǎn)坐標(biāo)可以隨便整數(shù)

? ? p2.y=-1;//控制點(diǎn)坐標(biāo)可以隨便整數(shù)

? ? p3.x = 1100;//比如這是起終點(diǎn)x

? ? p3.y = 600;//比如這是起終點(diǎn)y

? ? k = (p3.y*1.0-p0.y*1.0)/(p3.x*1.0-p0.x*1.0);

? ? b = p0.y*1.0 - k * p0.x*1.0;

? ? //printf("k,b = %f, %f\n",k,b);

? ? while(p1.y>1399 || p1.y<0){//改變控制點(diǎn)的y值不要偏的太離譜 可以改動(dòng)300越小波動(dòng)越小

? ? ? ? p1.y = k*p1.x*1.0+b+(rand()%300-150)*1.0;

? ? ? ? //printf("打印控制點(diǎn)坐標(biāo)p1.x = %d? p1.y = %d %f \n",p1.x,p1.y,k*p1.x*1.0+b);

? ? }

? ? while(p2.y>1399 || p2.y<0){

? ? ? ? p2.y = k*p2.x*1.0+b+(rand()%300-150)*1.0;

? ? ? ? //printf("p2.x = %d? p2.y = %d %f \n",p2.x,p2.y,k*p1.x*1.0+b);

? ? }

? ? printf("打印控制點(diǎn)坐標(biāo)p1=%d,%d? ? p2=%d,%d\n",p1.x,p1.y,p2.x,p2.y);

? ? float? t = 0.01;//曲線參數(shù)t

? ? float temp = 1 - t;

? ? printf("輸出軌跡\nx = [");

? ? for(t=0;t<1;t+=0.01)

? ? {

? ? ? ? temp = 1 - t;

? ? ? ? pot.x = p0.x * temp * temp * temp + 3 * p1.x * t * temp * temp + 3 * p2.x * t * t * temp + p3.x * t * t * t;

? ? ? ? printf("%d,",pot.x);

? ? }

? ? printf("]\ny = [");

? ? for(t=0;t<1;t+=0.01)

? ? {

? ? ? ? temp = 1 - t;

? ? ? ? pot.y = p0.y * temp * temp * temp + 3 * p1.y * t * temp * temp + 3 * p2.y * t * t * temp + p3.y * t * t * t;

? ? ? ? printf("%d,",pot.y);

? ? }

? ? printf("]\n");

? ? return 0;

}

還有

圖用python畫了 颁湖,c語(yǔ)言太麻煩了 就直接打印坐標(biāo)啦 湊活看吧 嘻嘻嘻 不服來(lái)找我?我家住番斗大街番斗花園2號(hào)樓1001室宣蠕,?我爸叫胡英俊,我媽叫張小麗甥捺,?我叫胡圖圖

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末抢蚀,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子镰禾,更是在濱河造成了極大的恐慌思币,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,402評(píng)論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件羡微,死亡現(xiàn)場(chǎng)離奇詭異谷饿,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)妈倔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門博投,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人盯蝴,你說(shuō)我怎么就攤上這事毅哗。” “怎么了捧挺?”我有些...
    開封第一講書人閱讀 162,483評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵虑绵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我闽烙,道長(zhǎng)翅睛,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,165評(píng)論 1 292
  • 正文 為了忘掉前任黑竞,我火速辦了婚禮捕发,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘很魂。我一直安慰自己扎酷,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評(píng)論 6 388
  • 文/花漫 我一把揭開白布遏匆。 她就那樣靜靜地躺著法挨,像睡著了一般。 火紅的嫁衣襯著肌膚如雪幅聘。 梳的紋絲不亂的頭發(fā)上凡纳,一...
    開封第一講書人閱讀 51,146評(píng)論 1 297
  • 那天,我揣著相機(jī)與錄音喊暖,去河邊找鬼惫企。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的狞尔。 我是一名探鬼主播丛版,決...
    沈念sama閱讀 40,032評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼偏序!你這毒婦竟也來(lái)了页畦?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,896評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤研儒,失蹤者是張志新(化名)和其女友劉穎豫缨,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體端朵,經(jīng)...
    沈念sama閱讀 45,311評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡好芭,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了冲呢。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片舍败。...
    茶點(diǎn)故事閱讀 39,696評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖敬拓,靈堂內(nèi)的尸體忽然破棺而出邻薯,到底是詐尸還是另有隱情,我是刑警寧澤乘凸,帶...
    沈念sama閱讀 35,413評(píng)論 5 343
  • 正文 年R本政府宣布厕诡,位于F島的核電站,受9級(jí)特大地震影響营勤,放射性物質(zhì)發(fā)生泄漏灵嫌。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評(píng)論 3 325
  • 文/蒙蒙 一冀偶、第九天 我趴在偏房一處隱蔽的房頂上張望醒第。 院中可真熱鬧,春花似錦进鸠、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至漠吻,卻和暖如春量瓜,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背途乃。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工绍傲, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,698評(píng)論 2 368
  • 正文 我出身青樓烫饼,卻偏偏與公主長(zhǎng)得像猎塞,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子杠纵,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容