2

是否有任何将位图数据传递到 iOS 并返回修改后副本的示例。我正在尝试将位图转换为 jpeg - 类似于 Windows http://blog.magicalhobo.com/2011/09/12/air-3-native-extension-imagepro cessor/ 中的此示例,但它每次都崩溃。

我很确定我在做一些基本的错误,但不是 iOS / Objective C 程序员我真的只是在尝试魔法咒语,我找不到任何好的例子。任何帮助表示赞赏?

肖恩

PS以下是我的尝试:

FREObject encodeJPEG(FREContext ctx, void* funcData, uint32_t argc, FREObject argv[])
{
  FREObject     objectBitmapData = argv[0];
  FREBitmapData bitmapData;

  FREAcquireBitmapData(objectBitmapData, &bitmapData);

  int width       = bitmapData.width;
  int height      = bitmapData.height;
  int stride      = bitmapData.lineStride32 * 4;
  uint32_t* input = bitmapData.bits32;

  FREReleaseBitmapData(objectBitmapData);


  UIImage *myImage = [UIImage imageWithData:input];
  NSData *jpgData  = UIImageJPEGRepresentation(myImage, 0.9);    

  FREObject    objectByteArray = argv[1];
  FREByteArray byteArray;

  FREObject length;

  FRENewObjectFromUint32(jpgData.length, &length);

  FRESetObjectProperty(objectByteArray, (const uint8_t*) "length", length, NULL);

  FREAcquireByteArray(objectByteArray, &byteArray);

  memcpy(byteArray.bytes, jpgData.bytes, jpgData.length);
  FREReleaseByteArray(objectByteArray);

  return NULL;

}

4

3 回答 3

3

Finale 版本 - 似乎工作正常 - 编码正常,我认为自己可以清理。

肖恩

FREObject encodeJPEG( FREContext ctx, void* funcData, uint32_t argc, FREObject argv[] )
{
FREObject       objectBitmapData = argv[ 0 ];
FREBitmapData2  bitmapData;

FREAcquireBitmapData2( objectBitmapData, &bitmapData );

int width       = bitmapData.width;
int height      = bitmapData.height;
int stride      = bitmapData.lineStride32 * 4;
uint32_t* input = bitmapData.bits32;

// make data provider from buffer
CGDataProviderRef provider = CGDataProviderCreateWithData(NULL, bitmapData.bits32, (width * height * 4), NULL);

// set up for CGImage creation
int                     bitsPerComponent    = 8;
int                     bitsPerPixel        = 32;
int                     bytesPerRow         = 4 * width;
CGColorSpaceRef         colorSpaceRef       = CGColorSpaceCreateDeviceRGB();    
CGBitmapInfo            bitmapInfo;

if( bitmapData.hasAlpha )
{
    if( bitmapData.isPremultiplied )
        bitmapInfo = kCGBitmapByteOrder32Little | kCGImageAlphaPremultipliedFirst; 
    else
        bitmapInfo = kCGBitmapByteOrder32Little | kCGImageAlphaFirst;            
}
else
{
    bitmapInfo = kCGBitmapByteOrder32Little | kCGImageAlphaNoneSkipFirst;  
}

CGColorRenderingIntent  renderingIntent     = kCGRenderingIntentDefault;
CGImageRef              imageRef            = CGImageCreate(width, height, bitsPerComponent, bitsPerPixel, bytesPerRow, colorSpaceRef, bitmapInfo, provider, NULL, NO, renderingIntent);

// make UIImage from CGImage
UIImage *myImage = [UIImage imageWithCGImage:imageRef];    
NSData* jpgData  = UIImageJPEGRepresentation( myImage, 0.9 );    

FREReleaseBitmapData( objectBitmapData );

FREObject    objectByteArray = argv[ 1 ];               
FREByteArray byteArray;
FREObject    length;

FRENewObjectFromUint32( jpgData.length, &length );
FRESetObjectProperty( objectByteArray, ( const uint8_t* ) "length", length, NULL );
FREAcquireByteArray( objectByteArray, &byteArray );

memcpy( byteArray.bytes, jpgData.bytes, jpgData.length );

FREReleaseByteArray( objectByteArray );

// release bits
CGColorSpaceRelease(colorSpaceRef);
CGImageRelease(imageRef);
CGDataProviderRelease(provider);    
return NULL;

}

于 2011-12-17T03:43:01.350 回答
0

这有点工作,除了红色是 jpeg 中的蓝色,并且不确定我是否发布了所有内容。

那是明天的战斗。

肖恩

FREObject encodeJPEG( FREContext ctx, void* funcData, uint32_t argc, FREObject argv[] )  
{
 FREObject       objectBitmapData = argv[ 0 ];
 FREBitmapData2  bitmapData;

 FREAcquireBitmapData2( objectBitmapData, &bitmapData );

 int width       = bitmapData.width;
 int height      = bitmapData.height;
 int stride      = bitmapData.lineStride32 * 4;
 uint32_t* input = bitmapData.bits32;

 // make data provider from buffer
 CGDataProviderRef provider = CGDataProviderCreateWithData(NULL, bitmapData.bits32, (width * height * 4), NULL);

 // set up for CGImage creation
 int                     bitsPerComponent    = 8;
 int                     bitsPerPixel        = 32;
 int                     bytesPerRow         = 4 * width;
 CGColorSpaceRef         colorSpaceRef       = CGColorSpaceCreateDeviceRGB();
 CGBitmapInfo            bitmapInfo          = kCGBitmapByteOrderDefault | kCGImageAlphaPremultipliedFirst;
 CGColorRenderingIntent  renderingIntent     = kCGRenderingIntentDefault;
 CGImageRef              imageRef            = CGImageCreate(width, height, bitsPerComponent, bitsPerPixel, bytesPerRow, colorSpaceRef, bitmapInfo, provider, NULL, NO, renderingIntent);

 // make UIImage from CGImage
 UIImage *myImage = [UIImage imageWithCGImage:imageRef];    
 NSData* jpgData  = UIImageJPEGRepresentation( myImage, 0.9 );    

 FREReleaseBitmapData( objectBitmapData );

 FREObject    objectByteArray = argv[ 1 ];               
 FREByteArray byteArray;
 FREObject    length;

 FRENewObjectFromUint32( jpgData.length, &length );
 FRESetObjectProperty( objectByteArray, ( const uint8_t* ) "length", length, NULL );
 FREAcquireByteArray( objectByteArray, &byteArray );

 memcpy( byteArray.bytes, jpgData.bytes, jpgData.length );

 FREReleaseByteArray( objectByteArray );

 return NULL;
}
于 2011-12-16T01:58:32.213 回答
0

交换红色和蓝色像素的位置

您从 iOS 获得的格式是:0xAARRGGBB
并且预期在 AIR 应用程序上显示的格式是:0xAABBGGRR

于 2012-02-02T14:59:02.867 回答