IOS: используйте .png, чтобы раскрасить вид - PullRequest
2 голосов
/ 21 марта 2012

У меня есть этот код:

-(void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event {
mouseSwiped = YES;

UITouch *touch = [touches anyObject];   
CGPoint currentPoint = [touch locationInView:drawImage];

UIGraphicsBeginImageContext(drawImage.frame.size);
[drawImage.image drawInRect:CGRectMake(0, 0, drawImage.frame.size.width, drawImage.frame.size.height)];
CGContextSetLineCap(UIGraphicsGetCurrentContext(), kCGLineCapRound);
CGContextSetLineWidth(UIGraphicsGetCurrentContext(), 15.0);

CGContextSetRGBStrokeColor(UIGraphicsGetCurrentContext(), 0, 0, 0, 1.0); //black

CGContextBeginPath(UIGraphicsGetCurrentContext());
CGContextMoveToPoint(UIGraphicsGetCurrentContext(), lastPoint.x, lastPoint.y);
CGContextAddLineToPoint(UIGraphicsGetCurrentContext(), currentPoint.x, currentPoint.y);
CGContextStrokePath(UIGraphicsGetCurrentContext());
drawImage.image = UIGraphicsGetImageFromCurrentImageContext();

UIGraphicsEndImageContext();

lastPoint = currentPoint;
}

с этим кодом я закрашиваю вид с черной линией, но я хочу закрасить определенным png (например, кистью);и иметь особый эффект;какие изменения я должен сделать?

Ответы [ 4 ]

2 голосов
/ 21 марта 2012

Я написал метод для получения цвета из CGPoint в изображении: ImageOperations.h:

+ (UIColor *)getColorFromImage:(UIImage*)image atX:(int)x andY:(int)y;

ImageOperations.m

+ (UIColor *)getColorFromImage:(UIImage*)image atX:(int)x andY:(int)y {
    CGImageRef imageRef = [image CGImage];
    NSUInteger width = CGImageGetWidth(imageRef);
    NSUInteger height = CGImageGetHeight(imageRef);
    CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();
    unsigned char *rawData = calloc(height * width * 4, sizeof(unsigned char));
    NSUInteger bytesPerPixel = 4;
    NSUInteger bytesPerRow = bytesPerPixel * width;
    NSUInteger bitsPerComponent = 8;
    CGContextRef context = CGBitmapContextCreate(rawData, width, height,
                                                 bitsPerComponent, bytesPerRow, colorSpace,
                                                 kCGImageAlphaPremultipliedLast | kCGBitmapByteOrder32Big);
    CGColorSpaceRelease(colorSpace);

    CGContextDrawImage(context, CGRectMake(0, 0, width, height), imageRef);
    CGContextRelease(context);

    int byteIdx = (bytesPerRow * y) + x * bytesPerPixel;

    CGFloat red   = (rawData[byteIdx]     * 1.0) / 255.0;
    CGFloat green = (rawData[byteIdx + 1] * 1.0) / 255.0;
    CGFloat blue  = (rawData[byteIdx + 2] * 1.0) / 255.0;
    CGFloat alpha = (rawData[byteIdx + 3] * 1.0) / 255.0;
    byteIdx += 4;

    UIColor *acolor = [UIColor colorWithRed:red/255.f
                                      green:green/255.f
                                       blue:blue/255.f    
                                      alpha:alpha/255.f];      
    free(rawData);

    return acolor;
}

Вызов метода выглядит так:

UIColor *myColor= [ImageOperations getColorFromImage:myImage atX:cgPoint.x andY:cgPoint.y];

self.myView.backgroundColor = myColor;

Надеюсь, это поможет.

0 голосов
/ 21 июня 2012

Вы можете использовать цвет рисунка или рисунок мазка Чтобы установить цвет рисунка:

Пожалуйста, убедитесь, что изображение имеет размер 320x480

CGContextSetStrokeColorWithColor(UIGraphicsGetCurrentContext(), [UIColor colorWithPatternImage:myimage].CGColor);
0 голосов
/ 21 марта 2012
CGContextSetRGBStrokeColor(UIGraphicsGetCurrentContext(), r, g, b, alpha);
in your code  u set r g b -->0
CGContextSetRGBStrokeColor(UIGraphicsGetCurrentContext(), 0, 0, 0, 1.0); 

that why its coming in black color, u need to set some value e.g
CGContextSetRGBStrokeColor(UIGraphicsGetCurrentContext(), 20, 50, 10, 1.0); 
0 голосов
/ 21 марта 2012

Если ваше растровое изображение png имеет только один цвет, то вы можете установить это значение rgb. Если вы хотите нарисовать png как путь, используйте ту же технику, что и для рисования линии с использованием точек. В строке постарайтесь добиться этого, разместив png изображения. Я имею в виду, что ваш одиночный png ведет себя как точка.

...