【HTML5】Canvas-------HTML5与OC绘制的简单对比&&HTML5简单绘制

HTML5里最让我沉醉的,也是最吸引人注意的就是Canvas和JavaScript,这两者的结合,更是让我感到“代码也可以变得如此迷人”。


HTML5与OC绘制的简单对比

实际上OC和HTML5在图形绘制上很像。

在OC语言中

CGContent cont = UIGraphicsGetCurrentContext(); 获取画布
CGPointMake 制造坐标点
CGContextAddLines(context, aPoint, int) 添加线段
CGContextDrawPath 开始绘制
CGContextSetStrokeColorWithColor 线框颜色

在HTML5中

var canvas_one = document.getElementById(id); 获取画布
moveTo 制造坐标点
lineTo 制造其他坐标,连接成线(类似于OC的添加线段)
content.stroke() 开始绘制
content.strokeStyle 线框颜色

OC和HTML5图形的绘制上面都大同小异,他们彼此之间都有绘制线段、线条、矩形、圆形、扇形、曲线、图形填充、渐变填充。

PS:对比未完,本人只抽取了基础绘制进行讲解

HTML5简单绘制

1、建构一个画布 <canvas></canvas>
2、设置绘制内容
3、调用绘制于现实

线段的绘制
function drawStangel() {  
  //画一条 
   var canvas_one = document.getElementById("canvasone"); 
   if (canvas_one.getContext) {     
   var content = canvas_one.getContext("2d");    
    //至关重要,参数必须写2d,表示要做平面绘图  
  }  
 content.beginPath(); 
 content.moveTo(5,5);//起点  
 content.lineTo(200,10);//终点坐标 
 content.lineWidth = 5.0;//线框度  
 content.strokeStyle = '#CC0000';//线颜色    
 content.stroke();
}
drawStangel();
以上代码完成的画线.png

绘制内容步骤

1.获取画布
2.告诉计算机我要进行平面绘制
3.准备绘制
4.建构绘制点及其属性
5.开始绘制

贝塞尔曲线的绘制
function Beisizer() { 
   var beisizer = document.getElementById("canvasone"); 
   if (beisizer == null){    
    return false;   
 }  
  var ContenofBeisizer = beisizer.getContext("2d");  
  ContenofBeisizer.moveTo(50,50); 
  ContenofBeisizer.bezierCurveTo(50 , 50 , 150, 50, 150, 150);    
  ContenofBeisizer.stroke(); 
  ContenofBeisizer.quadraticCurveTo(150, 250, 250, 250); 
   //这里第二个参数很重要赋值!=150    
ContenofBeisizer.stroke();
}
Beisizer();

曲线绘制.png

PS:(贝塞尔曲线内容丰富,可以单独研究一下它,所有的贝塞尔绘制都是如出一辙的,掌握了贝塞尔曲线的真理,在其他编程语言里对于绘图也会获益匪浅的)
推荐阅读,贝塞尔曲线的绘制详解

//OC的贝塞尔曲线绘制
 //二次曲线  
    CGContextMoveToPoint(context, 120, 300);//设置Path的起点  
    CGContextAddQuadCurveToPoint(context,190, 310, 120, 390);//设置贝塞尔曲线的控制点坐标和终点坐标  
    CGContextStrokePath(context);  
    //三次曲线函数  
    CGContextMoveToPoint(context, 200, 300);//设置Path的起点  
    CGContextAddCurveToPoint(context,250, 280, 250, 400, 280, 300);//设置贝塞尔曲线的控制点坐标和控制点坐标终点坐标  
    CGContextStrokePath(context);  

HTML5和OC的贝塞尔曲线绘制是不是有特别像啊,他们的步骤都差不多一致。

阴影图形的绘制
function shadow() { 
   var shadow = document.getElementById("canvastwo");  
  if (shadow == null){    
    return false; 
   } 
   var contentShadow = shadow.getContext("2d");    
   contentShadow.shadowOffsetX = 20;  //阴影偏移x轴
   contentShadow.shadowOffsetY = 15; //阴影偏移y轴
   contentShadow.shadowBlur = 10; //阴影模糊程度
   contentShadow.shadowColor = '#CFCFCF';  //阴影颜色
    //下面是设置canvastwo的属性
    contentShadow.fillStyle = '#FFAEB9';   //canvas图形填充颜色
    contentShadow.fillRect(5,5,200,150);  //canvas图形建构
}
shadow();
阴影效果图.png

对于阴影图形的绘制与OC比较起来,HTML5是较为容易理解的。

文章内容不难,本人开发iOS有些时间了,结合HTML5理解了一下简单绘制,如有不正确的地方可以一起来探讨。OC与HTML5的结合理解,望能够帮助更多的人理解图形绘制。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容

  • 一:canvas简介 1.1什么是canvas? ①:canvas是HTML5提供的一种新标签 ②:HTML5 ...
    GreenHand1阅读 4,679评论 2 32
  • 书中代码示例效果展示:Core HTML5 Canvas Examples 基础知识 canvas元素 canva...
    szu_bee阅读 2,822评论 2 28
  • 一、canvas简介 1.1 什么是canvas?(了解) 是HTML5提供的一种新标签 Canvas是一个矩形区...
    Looog阅读 3,941评论 3 40
  • --绘图与滤镜全面解析 概述 在iOS中可以很容易的开发出绚丽的界面效果,一方面得益于成功系统的设计,另一方面得益...
    韩七夏阅读 2,720评论 2 10
  • 我每天都送孩子去幼儿园,其实这件事情在孩子的爷爷奶奶接下“交接棒”的时候,曾想过“偷懒”。在家里吃完早餐直接上班,...
    茉莉大大阅读 197评论 0 1