Точка "cpbitmap" Изображения (imgaename.cpbitmap) - PullRequest
1 голос
/ 03 ноября 2011

Как я могу преобразовать изображения .cpbitmap в .png или обычный тип изображений?

Спасибо:)

Ответы [ 3 ]

3 голосов
/ 23 января 2014

На самом деле идея написания кода на Python превосходна, так как ее легче выполнить, чем запускать некоторые вещи xcode.

Как сказал предыдущий автор, он не тестировал код, но я это сделал.Я обнаружил, что он создает изображение, в котором компоненты RED и BLUE являются неправильными.

Вот почему я решил опубликовать правильную версию этого кода здесь:

#!/usr/bin/python
from PIL import Image,ImageOps
import struct
import sys
if len(sys.argv) < 3:
    print "Need two args: filename and result_filename\n";
    sys.exit(0)
filename = sys.argv[1]
result_filename = sys.argv[2]

with open(filename) as f:
    contents = f.read()
    unk1, width, height, unk2, unk3, unk4 = struct.unpack('<6i', contents[-24:])
    im = Image.fromstring('RGBA', (width,height), contents, 'raw', 'RGBA', 0, 1)
    r,g,b,a = im.split()
    im = Image.merge('RGBA', (b,g,r,a))
    im.save(result_filename)

Поместите этокод в файле decode_cpbitmap, выполните

chmod 755 decode_cpbitmap

, чтобы сделать его исполняемым, и теперь вы можете вызывать его следующим образом:

./decode_cpbitmap input_filename output_filename

где input_filename - это файл * .cpbitmap, который у вас уже есть и который вы хотите декодировать, а output_filename - smth.png (он будет создан с помощью этого кода).


Вы можете получить ошибку ImportError: No module named PIL

Затем необходимо установить модуль PIL Python.Я не буду объяснять, как устанавливать модули Python, поскольку вы можете найти его в другом месте.

2 голосов
/ 04 ноября 2011

Вот небольшая программа на Python, чтобы сделать это. Я не смог проверить это, потому что у меня нет изображений .cpbitmap для использования.

from PIL import Image
import struct
with open(filename) as f:
    contents = f.read()
unk1, width, height, unk2, unk3, unk4 = struct.unpack('<6i', contents[-24:])
im = Image.fromstring('RGBA', (width,height), contents, 'raw', 'RGBA', 0, 1)
im.save('converted.png')
1 голос
/ 09 января 2018

Я пытался конвертировать изображения из iOS 11, и эти скрипты не работают. Сегодня размер каждой строки округляется до 8 пикселей путем заполнения.

Я написал скрипт Node.JS. Перед запуском скрипта установите модуль jimp (npm install jimp). Протестировано на Node.JS v9.2.0 и jimp 0.2.28.

const fs = require('fs')
const util = require('util')

const Jimp = require('jimp')

const main = async () => {
    if (process.argv.length != 4) {
        console.log('Need two args: input filename and result filename')
        console.log(`Example: ${process.argv[0]} ${process.argv[1]} HomeBackground.cpbitmap HomeBackground.png`)
        return
    }

    const inpFileName = process.argv[2]
    const outFileName = process.argv[3]

    const readFile = util.promisify(fs.readFile)

    const cpbmp = await readFile(inpFileName)
    const width = cpbmp.readInt32LE(cpbmp.length - 4 * 5)
    const height = cpbmp.readInt32LE(cpbmp.length - 4 * 4)

    console.log(`Image height: ${height}, width: ${width}`)

    const image = await new Jimp(width, height, 0x000000FF)

    const calcOffsetInCpbmp = (x, y, width) => {
        const lineSize = Math.ceil(width / 8) * 8
        return x * 4 + y * lineSize * 4
    }

    const calcOffsetInImage = (x, y, width) => {
        return x * 4 + y * width * 4
    }

    const swapRBColors = (c) => {
        const r = c & 0xFF
        const b = (c & 0xFF0000) >> 16
        c &= 0xFF00FF00
        c |= r << 16
        c |= b
        return c
    }

    for (let y = 0; y < height; y++) {
        for (let x = 0; x < width; x++) {
            const color = cpbmp.readInt32LE(calcOffsetInCpbmp(x, y, width))
            image.bitmap.data.writeInt32LE(swapRBColors(color), calcOffsetInImage(x, y, width))
        }
    }

    await image.write(outFileName)

    console.log('Done')
}

main()
...