// Copyright (c) 2015 GitHub, Inc. // Use of this source code is governed by the MIT license that can be // found in the LICENSE file. #ifndef ATOM_COMMON_API_ATOM_API_NATIVE_IMAGE_H_ #define ATOM_COMMON_API_ATOM_API_NATIVE_IMAGE_H_ #include #include "native_mate/handle.h" #include "native_mate/wrappable.h" #include "ui/gfx/image/image.h" class GURL; namespace base { class FilePath; } namespace gfx { class Size; } namespace atom { namespace api { class NativeImage : public mate::Wrappable { public: static mate::Handle CreateEmpty(v8::Isolate* isolate); static mate::Handle Create( v8::Isolate* isolate, const gfx::Image& image); static mate::Handle CreateFromPNG( v8::Isolate* isolate, const char* buffer, size_t length); static mate::Handle CreateFromJPEG( v8::Isolate* isolate, const char* buffer, size_t length); static mate::Handle CreateFromPath( v8::Isolate* isolate, const base::FilePath& path); static mate::Handle CreateFromDataURL( v8::Isolate* isolate, const GURL& url); // The default constructor should only be used by image_converter.cc. NativeImage(); const gfx::Image& image() const { return image_; } protected: explicit NativeImage(const gfx::Image& image); virtual ~NativeImage(); // mate::Wrappable: mate::ObjectTemplateBuilder GetObjectTemplateBuilder( v8::Isolate* isolate) override; private: #if defined(OS_MACOSX) // Mark the image as template image if possible. static void MakeTemplateImage(gfx::Image* image); #endif v8::Handle ToPNG(v8::Isolate* isolate); v8::Handle ToJPEG(v8::Isolate* isolate, int quality); std::string ToDataURL(); bool IsEmpty(); gfx::Size GetSize(); gfx::Image image_; DISALLOW_COPY_AND_ASSIGN(NativeImage); }; } // namespace api } // namespace atom #endif // ATOM_COMMON_API_ATOM_API_NATIVE_IMAGE_H_