作者:rainycap
项目:magic
// FloatMatrix returns an Image in the GRAY colorspace as FloatMatrix,
// where each pixel represents an element of the matrix. Each element
// is normalized to the [0,1] range.
func (im *Image) FloatMatrix() (FloatMatrix, error) {
if im.Colorspace() != GRAY {
return nil, fmt.Errorf("FloatMatrix() is available only for GRAY images, this one is in %s", im.Colorspace())
}
width := im.Width()
height := im.Height()
ptrs := make([]*C.double, width)
for ii := range ptrs {
ptrs[ii] = allocDoublePtr(height)
}
defer func() {
for _, p := range ptrs {
freeDoublePtr(p)
}
}()
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
C.image_matrix(im.image, (**C.double)(unsafe.Pointer(&ptrs[0])), &ex)
if ex.severity != C.UndefinedException {
return nil, exError(&ex, "generating float matrix")
}
m := make([][]float64, width)
for ii := range m {
m[ii] = doublePtrToFloat64Slice(ptrs[ii], height)
}
return FloatMatrix(m), nil
}
作者:jbardi
项目:go_talk
func main() {
// Some GraphicsMagick boilerplate
C.InitializeMagick(nil)
defer C.DestroyMagick()
C.GetExceptionInfo(&exceptionInfo)
imageInfo = C.CloneImageInfo(nil)
defer C.DestroyExceptionInfo(&exceptionInfo)
defer C.DestroyImageInfo(imageInfo)
// main OMIT
Show("./cgo/armed_gopher.jpg")
img, err := Read("./cgo/armed_gopher.jpg")
if err != nil {
fmt.Println(err)
return
}
if img, err = Resize(img, 200, 800); err != nil {
fmt.Println("resize error:", err)
return
}
if err = Save(img, "./cgo/resized_gopher.jpg"); err != nil {
fmt.Println("save error:", err)
return
}
Show("./cgo/resized_gopher.jpg")
}
作者:roylo
项目:magic
func (im *Image) fn(what string, f C.ImageFunc) (*Image, error) {
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
res := C.bridge_image_func(f, im.image, &ex)
return checkImage(res, nil, &ex, what)
}
作者:kilny
项目:magic
func (im *Image) Roll(xoffset, yoffset int) (*Image, error) {
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
rolled := C.RollImage(im.image, magickLong(xoffset), magickLong(yoffset), &ex)
return checkImage(rolled, nil, &ex, "rolling")
}
作者:Kimbse
项目:magic
// Composite modifies the image, drawing the draw Image argument at offset
// (x, y) using the c Composite operation.
func (im *Image) Composite(c Composite, draw *Image, x int, y int) error {
op, err := im.compositeOperator(c)
if err != nil {
return err
}
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
var data C.CompositeData
data.composite = C.int(op)
data.draw = draw.image
data.x = C.int(x)
data.y = C.int(y)
res, err := im.applyDataFunc("compositing", C.ImageDataFunc(C.compositeImage), &data)
// res.image will be != than im.image when im is a non
// coalesced animation
if res.image != im.image {
unrefImages(im.image)
initializeRefCounts(res.image)
refImages(res.image)
im.image = res.image
dontFree(res)
}
return err
}
作者:Kimbse
项目:magic
func (im *Image) IsPalette() (bool, error) {
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
b := C.IsPaletteImage(im.image, &ex)
if ex.severity != C.UndefinedException {
return false, exError(&ex, "getting isPalette")
}
return int(b) != 0, nil
}
作者:Kimbse
项目:magic
func (im *Image) NColors() (int, error) {
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
val := C.GetNumberColors(im.image, nil, &ex)
if ex.severity != C.UndefinedException {
return 0, exError(&ex, "getting colors")
}
return int(val), nil
}
作者:ma
项目:magic
// Negate inverts the colors in the image
func (im *MagickImage) Negate() (err error) {
exception := C.AcquireExceptionInfo()
defer C.DestroyExceptionInfo(exception)
new_image := C.Negate(im.Image, exception)
if failed := C.CheckException(exception); failed == C.MagickTrue {
return ErrorFromExceptionInfo(exception)
}
im.ReplaceImage(new_image)
return nil
}
作者:nicolasro
项目:magic
// ChannelDepth returns the depth of the given channel.
func (im *Image) ChannelDepth(ch Channel) (uint, error) {
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
ret := C.GetImageChannelDepth(im.image, C.ChannelType(ch), &ex)
if ex.severity != C.UndefinedException {
return 0, exError(&ex, "getting channel info")
}
return uint(ret), nil
}
作者:Kimbse
项目:magic
func (im *Image) statistics() (*Statistics, error) {
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
var stats C.ImageStatistics
C.GetImageStatistics(im.image, &stats, &ex)
if ex.severity != C.UndefinedException {
return nil, exError(&ex, "getting statistics")
}
return newStatistics(&stats), nil
}
作者:ma
项目:magic
// ParseGeometryToRectangleInfo converts from a geometry string (WxH+X+Y) into a Magick
// RectangleInfo that contains the individual properties
func (im *MagickImage) ParseGeometryToRectangleInfo(geometry string) (info C.RectangleInfo, err error) {
c_geometry := C.CString(geometry)
defer C.free(unsafe.Pointer(c_geometry))
exception := C.AcquireExceptionInfo()
defer C.DestroyExceptionInfo(exception)
C.ParseRegionGeometry(im.Image, c_geometry, &info, exception)
if failed := C.CheckException(exception); failed == C.MagickTrue {
err = ErrorFromExceptionInfo(exception)
}
return
}
作者:ma
项目:magic
// IntegralRotateImage rotates the image an integral of 90 degrees
func (im *MagickImage) IntegralRotateImage(rotations int) (err error) {
exception := C.AcquireExceptionInfo()
defer C.DestroyExceptionInfo(exception)
new_image := C.IntegralRotateImage(im.Image, C.size_t(rotations), exception)
if failed := C.CheckException(exception); failed == C.MagickTrue {
return ErrorFromExceptionInfo(exception)
}
im.ReplaceImage(new_image)
return nil
}
作者:kita
项目:magic
func (im *Image) applyFunc(what string, f C.ImageFunc) (*Image, error) {
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
res := C.apply_image_func(f, im.root(), unsafe.Pointer(im.parent), btoi(im.coalesced), &ex)
if res == nil {
return nil, exError(&ex, what)
}
ret := newImage(res, nil)
ret.coalesced = true
return ret, nil
}
作者:ma
项目:magic
// FillBackgroundColor fills transparent areas of an image with a solid color and stores the filled image in place.
// color can be any color format that image magick understands, see: http://www.imagemagick.org/ImageMagick-7.0.0/script/color.php#models
func (im *MagickImage) FillBackgroundColor(color string) (err error) {
exception := C.AcquireExceptionInfo()
defer C.DestroyExceptionInfo(exception)
c_color := C.CString(color)
defer C.free(unsafe.Pointer(c_color))
new_image := C.FillBackgroundColor(im.Image, c_color, exception)
if failed := C.CheckException(exception); failed == C.MagickTrue {
return ErrorFromExceptionInfo(exception)
}
im.ReplaceImage(new_image)
return nil
}
作者:kita
项目:magic
// Clone returns a copy of the image. If the image
// has multiple frames, it copies all of them. To
// Clone just one frame use im.Frame(i).Clone().
func (im *Image) Clone() (*Image, error) {
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
var image *C.Image
if im.parent == nil {
image = C.CloneImageList(im.image, &ex)
} else {
image = C.CloneImage(im.image, magickSize(0), magickSize(0), 1, &ex)
}
return checkImage(image, nil, &ex, "cloning")
}
作者:Kimbse
项目:magic
func (im *Image) statistics() (*Statistics, error) {
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
stats := C.GetImageChannelStatistics(im.image, &ex)
if stats != nil {
defer freeMagickMemory(unsafe.Pointer(stats))
}
if stats == nil || ex.severity != C.UndefinedException {
return nil, exError(&ex, "getting statistics")
}
return newStatistics(stats), nil
}
作者:kita
项目:magic
func (im *Image) applyDataFunc(what string, f C.ImageDataFunc, data interface{}) (*Image, error) {
p := unsafe.Pointer(reflect.ValueOf(data).Pointer())
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
res := C.apply_image_data_func(f, im.root(), p, unsafe.Pointer(im.parent), btoi(im.coalesced), &ex)
if res == nil {
return nil, exError(&ex, what)
}
ret := newImage(res, nil)
ret.coalesced = true
return ret, nil
}
作者:ma
项目:magic
// Crop crops the image based on the geometry string passed and stores the cropped image in place
// For more info about Geometry see http://www.imagemagick.org/script/command-line-processing.php#geometry
func (im *MagickImage) Crop(geometry string) (err error) {
exception := C.AcquireExceptionInfo()
defer C.DestroyExceptionInfo(exception)
rect, err := im.ParseGeometryToRectangleInfo(geometry)
if err != nil {
return err
}
new_image := C.CropImage(im.Image, &rect, exception)
if failed := C.CheckException(exception); failed == C.MagickTrue {
return ErrorFromExceptionInfo(exception)
}
im.ReplaceImage(new_image)
return nil
}
作者:ma
项目:magic
// NewFromFile loads a file at filename into a MagickImage.
// Exceptions are returned as MagickErrors.
func NewFromFile(filename string) (im *MagickImage, err error) {
exception := C.AcquireExceptionInfo()
defer C.DestroyExceptionInfo(exception)
info := C.AcquireImageInfo()
c_filename := C.CString(filename)
defer C.free(unsafe.Pointer(c_filename))
C.SetImageInfoFilename(info, c_filename)
image := C.ReadImage(info, exception)
if failed := C.CheckException(exception); failed == C.MagickTrue {
C.DestroyImageInfo(info)
return nil, ErrorFromExceptionInfo(exception)
}
return &MagickImage{Image: image, ImageInfo: info}, nil
}
作者:kita
项目:magic
func decodeData(data []byte, try int) (*Image, error) {
if len(data) == 0 {
return nil, ErrNoData
}
info := C.CloneImageInfo(nil)
defer C.DestroyImageInfo(info)
var ex C.ExceptionInfo
C.GetExceptionInfo(&ex)
defer C.DestroyExceptionInfo(&ex)
im := C.BlobToImage(info, unsafe.Pointer(&data[0]), C.size_t(len(data)), &ex)
if im == nil && try < maxGifTries && ex.severity == C.CorruptImageError && looksLikeGif(data) {
return fixAndDecodeGif(data, try)
}
return checkImage(im, nil, &ex, "decoding")
}