我是靠谱客的博主 勤奋大船,最近开发中收集的这篇文章主要介绍自定义NSView【Cocoa(mac) Application 开发系列之三】自定义NSView并绘制一些常见的图形及字符串;,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

【Cocoa(mac) Application 开发系列之三】自定义NSView并绘制一些常见的图形及字符串;

本站文章均为 李华明Himi 原创,转载务必在明显处注明:(作者新浪微博: @李华明Himi ) 
转载自【黑米GameDev街区】 原文链接: http://www.himigame.com/mac-cocoa-application/908.html
 

          �7�4 点击订阅 �7�2 本博客最新动态!及时将最新博文通知您!

                 

不多说比较简单直接给出源码大家作为参考吧。

对于Cocoa application 话说回来比较easy如果之前你接触过iOS 的IB的话 基本上没什么可说的上手很快;

因此对于Cocoa Application 不会太快的更新接着Himi将对之前做的动编彻底的更新一版;后期有时间将继续更新此系列;

  言归正传对于自定义NSView上一篇已经介绍了而且本篇主要继续深入NSView的drawRect进行继续研究示例代码如下比较容易理解而且都已备注的很清楚;
//
//  HView.m
//
//  Created by Himi on 12-6-7.
//  Copyright (c) 2012年 Himi. All rights reserved.
//

#import "HView.h"

@implementation HView

- (id)initWithFrame:(NSRect)frame
{
    self = [super initWithFrame:frame];
    if (self) {
        // Initialization code here.
    }

    return self;
}

- (void)drawRect:(NSRect)dirtyRect
{

    //-----------获取整个MyView尺寸------------
    NSRect screen = [self bounds];
    int SW = screen.size.width;
    int SH = screen.size.height;

    //-----------设置整个MyView的颜色------------
    [[NSColor grayColor] set];

    //-----------填充整个MyView---------------
    NSRectFill(screen);

    //-----------绘制字符串---------------
    NSString * strH= @"基础绘制   --By Himi";
    //--绘制不带属性字符串
    [strH drawAtPoint:NSMakePoint(SH*0.5, SH-30) withAttributes:NULL];
    //--绘制带属性字符串
    NSMutableDictionary *md = [NSMutableDictionary dictionary];
    [md setObject:[NSFont fontWithName:@"Times" size:20] forKey:NSFontAttributeName];
    [strH drawAtPoint:NSMakePoint(SH*0.5, SH-70) withAttributes:md];

    //--------绘制矩形----
    NSRect rect1 = NSMakeRect(SH*0.5, SH-100, 30, 20);
    NSRect rect2 = NSMakeRect(SH*0.5, SH-130, 30, 20);
    //填充矩形
    [NSBezierPath fillRect:rect1];
    //绘制矩形
    [NSBezierPath strokeRect:rect2];

    //--------绘制线条(十字线)----
    [[NSColor greenColor] set];
    NSPoint  bm =NSMakePoint(SW*0.5, 0);
    NSPoint  top =NSMakePoint(SW*0.5, SH);
    NSPoint  lf =NSMakePoint(0, SH*0.5);
    NSPoint  rt =NSMakePoint(SW, SH*0.5);
    [NSBezierPath strokeLineFromPoint:bm toPoint:top];
    [NSBezierPath strokeLineFromPoint:lf toPoint:rt];

    //-------绘制椭圆
    [[NSColor redColor] set];
    [[NSBezierPath bezierPathWithOvalInRect:screen] stroke];

    [self setNeedsDisplay:YES];// 强制绘画

//【备注】
//    CGContextRef ref = [[NSGraphicsContext currentContext] graphicsPort];// 获取画布
//    CGContextFlush(ref);//刷新画布
}

-(void) mouseDragged:(NSEvent *)theEvent{
    NSPoint mp = [self convertPoint:[theEvent locationInWindow] fromView:nil];// 鼠标新坐标
    NSLog(@"mouseDragged~%f,%f",mp.x,mp.y);

}
-(void) mouseUp:(NSEvent *)theEvent{
    NSLog(@"mouseUp");

}
-(void) mouseDown:(NSEvent *)theEvent{
    NSLog(@"mouseDown");

}
@end

�0�2注意的是:备注�0�2这两行代码是直接通过获取画布更新画布进行绘制其中绘制代码省略比较容易这里起个头推荐使用此种方式绘制;对于做游戏的我们对于画布刷新画布我想是再熟悉不过了!


最后

以上就是勤奋大船为你收集整理的自定义NSView【Cocoa(mac) Application 开发系列之三】自定义NSView并绘制一些常见的图形及字符串;的全部内容,希望文章能够帮你解决自定义NSView【Cocoa(mac) Application 开发系列之三】自定义NSView并绘制一些常见的图形及字符串;所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(61)

评论列表共有 0 条评论

立即
投稿
返回
顶部