ANE, iOS и BitmapData - PullRequest
       31

ANE, iOS и BitmapData

2 голосов
/ 15 декабря 2011

Есть ли какой-нибудь пример передачи растровых данных в iOS и возврата модифицированной копии.Я пытаюсь преобразовать растровое изображение в jpeg - аналогично этому примеру в Windows http://blog.magicalhobo.com/2011/09/12/air-3-native-extension-imagepro cessore /, но каждый раз он вылетал.

Я почти уверен, что делаю что-то не так, но не программист для 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;

}

Ответы [ 3 ]

3 голосов
/ 17 декабря 2011

Финальная версия - кажется, работает нормально - кодирует нормально, и я думаю, что очищается после себя нормально.

Шон

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;

}

0 голосов
/ 02 февраля 2012

Обмен позиции красных и синих пикселей

формат, который вы получаете от iOS: 0xAARRGGBB
и тот, который должен отображаться в приложении AIR: 0xAABBGGRR

0 голосов
/ 16 декабря 2011

Это вроде работает, за исключением того, что красные цвета блюзовые в jpeg, и я не уверен, что у меня все в порядке.

Это завтрашняя битва.

Sean

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;
}
...