canvas常用方法封裝

我是進(jìn)行的uniapp開(kāi)發(fā)所以里邊有部分uniAPI 不需要的小伙伴可根據(jù)需求自行調(diào)整代碼

/**
 * 繪制圓角矩形
 * @exports
 * @param { Object } ctx ctx - canvas組件的繪圖上下文
 * @param { Number } x x - 矩形的x坐標(biāo)
 * @param { Number } y y - 矩形的y坐標(biāo)
 * @param { Number } w w - 矩形的寬度
 * @param { Number } h h - 矩形的高度
 * @param { Number } r r - 矩形的圓角半徑
 * @param { String } c [c = 'transparent'] - 矩形的填充色
 */
export function roundRect (ctx, x, y, w, h, r, c = '#fff') {
  if (w < 2 * r) { r = w / 2; }
  if (h < 2 * r) { r = h / 2; }

  ctx.beginPath();
  ctx.fillStyle = c;

  ctx.arc(x + r, y + r, r, Math.PI, Math.PI * 1.5);
  ctx.moveTo(x + r, y);
  ctx.lineTo(x + w - r, y);
  ctx.lineTo(x + w, y + r);

  ctx.arc(x + w - r, y + r, r, Math.PI * 1.5, Math.PI * 2);
  ctx.lineTo(x + w, y + h - r);
  ctx.lineTo(x + w - r, y + h);

  ctx.arc(x + w - r, y + h - r, r, 0, Math.PI * 0.5);
  ctx.lineTo(x + r, y + h);
  ctx.lineTo(x, y + h - r);

  ctx.arc(x + r, y + h - r, r, Math.PI * 0.5, Math.PI);
  ctx.lineTo(x, y + r);
  ctx.lineTo(x + r, y);

  ctx.fill();
  ctx.closePath();
}

/**
 * 繪制文字并上色
 * @exports
 * @param { Object } ctx ctx - canvas組件的繪圖上下文
 * @param { Number } text 所需要繪制的文字
 * @param { Number } font 文字字體
 * @param { Number } color 文字顏色
 * @param { Number } left 文字左側(cè)距離
 * @param { Number } right 文字頂部距離
 * @param { Number } fontSize 字體大小
 */
export function setFont (ctx, text, font, color, left, top, fontSize) {
  ctx.font = font;
  ctx.setFillStyle(color);
  typeof fontSize === 'number' && ctx.setFontSize(fontSize);
  ctx.fillText(text, left, top);
}

/**
 * 繪制圓形圖片
 * @exports
 * @param {*} ctx Canvas實(shí)例
 * @param {*} src 圖片地址
 * @param {*} x x軸坐標(biāo)
 * @param {*} y y軸坐標(biāo)
 * @param {*} r 圓形半徑
 * @description 如果在繪制圖片之后還有需要繪制別的元素囊陡,需啟動(dòng) save() 痒钝、restore() 方法溯革,否則 clip() 方法會(huì)導(dǎo)致之后元素都不可見(jiàn)
 */
export function createCircleImg (ctx, img, x, y) {
  uni.getImageInfo({
    src: img,
    success: ({ width, height }) => {
      ctx.save();
      let radius, diameter;
      radius = width > height ? height / 2 : width / 2;
      diameter = radius * 2;
      ctx.clearRect(0, 0, diameter, diameter);
      ctx.save();
      ctx.beginPath();
      ctx.arc(radius, radius, radius, 0, Math.PI * 2, false);
      ctx.clip();
      ctx.drawImage(img, 0, 0, diameter, diameter, 0, 0, diameter, diameter);
      ctx.draw();
    }
  });
}
/**
 * 繪制矩形
 * @exports
 * @param {*} ctx Canvas實(shí)例
 * @param {*} w 寬度
 * @param {*} h 高度
 * @param {*} x x坐標(biāo)
 * @param {*} y y坐標(biāo)
 * @param {*} color 背景顏色
 */
export function drawRect (ctx, w, h, x, y, color) {
  ctx.setFillStyle(color);
  ctx.fillRect(x, y, w, h);
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蛹头,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子椅寺,更是在濱河造成了極大的恐慌施籍,老刑警劉巖濒析,帶你破解...
    沈念sama閱讀 219,490評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異蝌焚,居然都是意外死亡裹唆,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門只洒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)许帐,“玉大人,你說(shuō)我怎么就攤上這事毕谴∥杩裕” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,830評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵析珊,是天一觀的道長(zhǎng)羡鸥。 經(jīng)常有香客問(wèn)我,道長(zhǎng)忠寻,這世上最難降的妖魔是什么惧浴? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,957評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮奕剃,結(jié)果婚禮上衷旅,老公的妹妹穿的比我還像新娘。我一直安慰自己纵朋,他們只是感情好柿顶,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評(píng)論 6 393
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著操软,像睡著了一般嘁锯。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,754評(píng)論 1 307
  • 那天家乘,我揣著相機(jī)與錄音蝗羊,去河邊找鬼。 笑死仁锯,一個(gè)胖子當(dāng)著我的面吹牛耀找,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播业崖,決...
    沈念sama閱讀 40,464評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼野芒,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了双炕?” 一聲冷哼從身側(cè)響起狞悲,我...
    開(kāi)封第一講書(shū)人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎雄家,沒(méi)想到半個(gè)月后效诅,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,847評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡趟济,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評(píng)論 3 338
  • 正文 我和宋清朗相戀三年乱投,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片顷编。...
    茶點(diǎn)故事閱讀 40,137評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡戚炫,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出媳纬,到底是詐尸還是另有隱情双肤,我是刑警寧澤,帶...
    沈念sama閱讀 35,819評(píng)論 5 346
  • 正文 年R本政府宣布钮惠,位于F島的核電站茅糜,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏素挽。R本人自食惡果不足惜蔑赘,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望预明。 院中可真熱鬧缩赛,春花似錦、人聲如沸撰糠。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,023評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)阅酪。三九已至旨袒,卻和暖如春汁针,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背峦失。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,149評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工扇丛, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留术吗,地道東北人尉辑。 一個(gè)月前我還...
    沈念sama閱讀 48,409評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像较屿,于是被迫代替她去往敵國(guó)和親隧魄。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評(píng)論 2 355

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