Run this command to install the SDK:
npm install cloudmersive-image-api-client --save
Or add this snippet to your package.json:
"dependencies": { "cloudmersive-image-api-client": "^1.3.4" }
Run this command to install the SDK:
npm install cloudmersive-image-api-client --save
Or add this snippet to your package.json:
"dependencies": { "cloudmersive-image-api-client": "^1.3.4" }
var CloudmersiveImageApiClient = require('cloudmersive-image-api-client');
var defaultClient = CloudmersiveImageApiClient.ApiClient.instance;
// Configure API key authorization: Apikey
var Apikey = defaultClient.authentications['Apikey'];
Apikey.apiKey = 'YOUR API KEY';
var apiInstance = new CloudmersiveImageApiClient.EditApi();
var baseImage = Buffer.from(fs.readFileSync("C:\\temp\\inputfile").buffer); // File | Image file to perform the operation on. Common file formats such as PNG, JPEG are supported.
var layeredImage = Buffer.from(fs.readFileSync("C:\\temp\\inputfile").buffer); // File | Image to layer on top of the base image.
var opts = {
'top': 56, // Number | Optional; Desired distance in pixels from the top of the base image to the top of the layered image.
'bottom': 56, // Number | Optional; Desired distance in pixels from the bottom of the base image to the bottom of the layered image.
'left': 56, // Number | Optional; Desired distance in pixels from the left side of the base image to the left side of the layered image.
'right': 56, // Number | Optional; Desired distance in pixels from the right side of the base image to the right side of the layered image.
'width': 56, // Number | Optional; Desired width of the layered image in pixels. Leave height empty or 0 to automatically scale the image proportionally.
'height': 56 // Number | Optional; Desired height of the layered image in pixels. Leave width empty or 0 to automatically scale the image proportionally.
};
var callback = function(error, data, response) {
if (error) {
console.error(error);
} else {
console.log('API called successfully. Returned data: ' + data);
}
};
apiInstance.editCompositePrecise(baseImage, layeredImage, opts, callback);
Run this command to install the SDK:
pip install cloudmersive-image-api-client
from __future__ import print_function
import time
import cloudmersive_image_api_client
from cloudmersive_image_api_client.rest import ApiException
from pprint import pprint
# Configure API key authorization: Apikey
configuration = cloudmersive_image_api_client.Configuration()
configuration.api_key['Apikey'] = 'YOUR_API_KEY'
# create an instance of the API class
api_instance = cloudmersive_image_api_client.EditApi(cloudmersive_image_api_client.ApiClient(configuration))
base_image = '/path/to/file' # file | Image file to perform the operation on. Common file formats such as PNG, JPEG are supported.
layered_image = '/path/to/file' # file | Image to layer on top of the base image.
top = 56 # int | Optional; Desired distance in pixels from the top of the base image to the top of the layered image. (optional)
bottom = 56 # int | Optional; Desired distance in pixels from the bottom of the base image to the bottom of the layered image. (optional)
left = 56 # int | Optional; Desired distance in pixels from the left side of the base image to the left side of the layered image. (optional)
right = 56 # int | Optional; Desired distance in pixels from the right side of the base image to the right side of the layered image. (optional)
width = 56 # int | Optional; Desired width of the layered image in pixels. Leave height empty or 0 to automatically scale the image proportionally. (optional)
height = 56 # int | Optional; Desired height of the layered image in pixels. Leave width empty or 0 to automatically scale the image proportionally. (optional)
try:
# Composite two images together precisely
api_response = api_instance.edit_composite_precise(base_image, layered_image, top=top, bottom=bottom, left=left, right=right, width=width, height=height)
pprint(api_response)
except ApiException as e:
print("Exception when calling EditApi->edit_composite_precise: %s\n" % e)
Run this command to install the SDK:
Install-Package Cloudmersive.APIClient.NET.ImageRecognition -Version 3.0.5
Run this command to install the SDK:
Install-Package Cloudmersive.APIClient.NETCore.ImageRecognition -Version 2.0.4
using System;
using System.Diagnostics;
using Cloudmersive.APIClient.NET.ImageRecognition.Api;
using Cloudmersive.APIClient.NET.ImageRecognition.Client;
using Cloudmersive.APIClient.NET.ImageRecognition.Model;
namespace Example
{
public class EditCompositePreciseExample
{
public void main()
{
// Configure API key authorization: Apikey
Configuration.Default.AddApiKey("Apikey", "YOUR_API_KEY");
var apiInstance = new EditApi();
var baseImage = new System.IO.FileStream("C:\\temp\\inputfile", System.IO.FileMode.Open); // System.IO.Stream | Image file to perform the operation on. Common file formats such as PNG, JPEG are supported.
var layeredImage = new System.IO.FileStream("C:\\temp\\inputfile", System.IO.FileMode.Open); // System.IO.Stream | Image to layer on top of the base image.
var top = 56; // int? | Optional; Desired distance in pixels from the top of the base image to the top of the layered image. (optional)
var bottom = 56; // int? | Optional; Desired distance in pixels from the bottom of the base image to the bottom of the layered image. (optional)
var left = 56; // int? | Optional; Desired distance in pixels from the left side of the base image to the left side of the layered image. (optional)
var right = 56; // int? | Optional; Desired distance in pixels from the right side of the base image to the right side of the layered image. (optional)
var width = 56; // int? | Optional; Desired width of the layered image in pixels. Leave height empty or 0 to automatically scale the image proportionally. (optional)
var height = 56; // int? | Optional; Desired height of the layered image in pixels. Leave width empty or 0 to automatically scale the image proportionally. (optional)
try
{
// Composite two images together precisely
byte[] result = apiInstance.EditCompositePrecise(baseImage, layeredImage, top, bottom, left, right, width, height);
Debug.WriteLine(result);
}
catch (Exception e)
{
Debug.Print("Exception when calling EditApi.EditCompositePrecise: " + e.Message );
}
}
}
}
using System;
using System.Diagnostics;
using Cloudmersive.APIClient.NETCore.ImageRecognition.Api;
using Cloudmersive.APIClient.NETCore.ImageRecognition.Client;
using Cloudmersive.APIClient.NETCore.ImageRecognition.Model;
namespace Example
{
public class EditCompositePreciseExample
{
public void main()
{
// Configure API key authorization: Apikey
Configuration.Default.AddApiKey("Apikey", "YOUR_API_KEY");
var apiInstance = new EditApi();
var baseImage = new System.IO.FileStream("C:\\temp\\inputfile", System.IO.FileMode.Open); // System.IO.Stream | Image file to perform the operation on. Common file formats such as PNG, JPEG are supported.
var layeredImage = new System.IO.FileStream("C:\\temp\\inputfile", System.IO.FileMode.Open); // System.IO.Stream | Image to layer on top of the base image.
var top = 56; // int? | Optional; Desired distance in pixels from the top of the base image to the top of the layered image. (optional)
var bottom = 56; // int? | Optional; Desired distance in pixels from the bottom of the base image to the bottom of the layered image. (optional)
var left = 56; // int? | Optional; Desired distance in pixels from the left side of the base image to the left side of the layered image. (optional)
var right = 56; // int? | Optional; Desired distance in pixels from the right side of the base image to the right side of the layered image. (optional)
var width = 56; // int? | Optional; Desired width of the layered image in pixels. Leave height empty or 0 to automatically scale the image proportionally. (optional)
var height = 56; // int? | Optional; Desired height of the layered image in pixels. Leave width empty or 0 to automatically scale the image proportionally. (optional)
try
{
// Composite two images together precisely
byte[] result = apiInstance.EditCompositePrecise(baseImage, layeredImage, top, bottom, left, right, width, height);
Debug.WriteLine(result);
}
catch (Exception e)
{
Debug.Print("Exception when calling EditApi.EditCompositePrecise: " + e.Message );
}
}
}
}
To install with Maven, add a reference to the repository in pom.xml:
<repositories> <repository> <id>jitpack.io</id> <url>https://jitpack.io</url> </repository> </repositories>
And add a reference to the dependency in pom.xml:
<dependencies> <dependency> <groupId>com.github.Cloudmersive</groupId> <artifactId>Cloudmersive.APIClient.Java</artifactId> <version>v4.25</version> </dependency> </dependencies>
To install with Gradle, add it in your root build.gradle at the end of repositories:
allprojects { repositories { ... maven { url 'https://jitpack.io' } } }
And add the dependency in build.gradle:
dependencies { implementation 'com.github.Cloudmersive:Cloudmersive.APIClient.Java:v4.25' }
// Import classes:
//import com.cloudmersive.client.invoker.ApiClient;
//import com.cloudmersive.client.invoker.ApiException;
//import com.cloudmersive.client.invoker.Configuration;
//import com.cloudmersive.client.invoker.auth.*;
//import com.cloudmersive.client.EditApi;
ApiClient defaultClient = Configuration.getDefaultApiClient();
// Configure API key authorization: Apikey
ApiKeyAuth Apikey = (ApiKeyAuth) defaultClient.getAuthentication("Apikey");
Apikey.setApiKey("YOUR API KEY");
// Uncomment the following line to set a prefix for the API key, e.g. "Token" (defaults to null)
//Apikey.setApiKeyPrefix("Token");
EditApi apiInstance = new EditApi();
File baseImage = new File("/path/to/file"); // File | Image file to perform the operation on. Common file formats such as PNG, JPEG are supported.
File layeredImage = new File("/path/to/file"); // File | Image to layer on top of the base image.
Integer top = 56; // Integer | Optional; Desired distance in pixels from the top of the base image to the top of the layered image.
Integer bottom = 56; // Integer | Optional; Desired distance in pixels from the bottom of the base image to the bottom of the layered image.
Integer left = 56; // Integer | Optional; Desired distance in pixels from the left side of the base image to the left side of the layered image.
Integer right = 56; // Integer | Optional; Desired distance in pixels from the right side of the base image to the right side of the layered image.
Integer width = 56; // Integer | Optional; Desired width of the layered image in pixels. Leave height empty or 0 to automatically scale the image proportionally.
Integer height = 56; // Integer | Optional; Desired height of the layered image in pixels. Leave width empty or 0 to automatically scale the image proportionally.
try {
byte[] result = apiInstance.editCompositePrecise(baseImage, layeredImage, top, bottom, left, right, width, height);
System.out.println(result);
} catch (ApiException e) {
System.err.println("Exception when calling EditApi#editCompositePrecise");
e.printStackTrace();
}
Run this command to install the SDK:
composer require cloudmersive/cloudmersive_imagerecognition_api_client
<?php
require_once(__DIR__ . '/vendor/autoload.php');
// Configure API key authorization: Apikey
$config = Swagger\Client\Configuration::getDefaultConfiguration()->setApiKey('Apikey', 'YOUR_API_KEY');
$apiInstance = new Swagger\Client\Api\EditApi(
new GuzzleHttp\Client(),
$config
);
$base_image = "/path/to/file"; // \SplFileObject | Image file to perform the operation on. Common file formats such as PNG, JPEG are supported.
$layered_image = "/path/to/file"; // \SplFileObject | Image to layer on top of the base image.
$top = 56; // int | Optional; Desired distance in pixels from the top of the base image to the top of the layered image.
$bottom = 56; // int | Optional; Desired distance in pixels from the bottom of the base image to the bottom of the layered image.
$left = 56; // int | Optional; Desired distance in pixels from the left side of the base image to the left side of the layered image.
$right = 56; // int | Optional; Desired distance in pixels from the right side of the base image to the right side of the layered image.
$width = 56; // int | Optional; Desired width of the layered image in pixels. Leave height empty or 0 to automatically scale the image proportionally.
$height = 56; // int | Optional; Desired height of the layered image in pixels. Leave width empty or 0 to automatically scale the image proportionally.
try {
$result = $apiInstance->editCompositePrecise($base_image, $layered_image, $top, $bottom, $left, $right, $width, $height);
print_r($result);
} catch (Exception $e) {
echo 'Exception when calling EditApi->editCompositePrecise: ', $e->getMessage(), PHP_EOL;
}
?>
Add the Objective-C client to your Podfile:
pod 'CloudmersiveImageRecognitionApiClient', '~> 1.0'
CMDefaultConfiguration *apiConfig = [CMDefaultConfiguration sharedConfig];
// Configure API key authorization: (authentication scheme: Apikey)
[apiConfig setApiKey:@"YOUR_API_KEY" forApiKeyIdentifier:@"Apikey"];
NSURL* baseImage = [NSURL fileURLWithPath:@"/path/to/file"]; // Image file to perform the operation on. Common file formats such as PNG, JPEG are supported.
NSURL* layeredImage = [NSURL fileURLWithPath:@"/path/to/file"]; // Image to layer on top of the base image.
NSNumber* top = @56; // Optional; Desired distance in pixels from the top of the base image to the top of the layered image. (optional)
NSNumber* bottom = @56; // Optional; Desired distance in pixels from the bottom of the base image to the bottom of the layered image. (optional)
NSNumber* left = @56; // Optional; Desired distance in pixels from the left side of the base image to the left side of the layered image. (optional)
NSNumber* right = @56; // Optional; Desired distance in pixels from the right side of the base image to the right side of the layered image. (optional)
NSNumber* width = @56; // Optional; Desired width of the layered image in pixels. Leave height empty or 0 to automatically scale the image proportionally. (optional)
NSNumber* height = @56; // Optional; Desired height of the layered image in pixels. Leave width empty or 0 to automatically scale the image proportionally. (optional)
CMEditApi*apiInstance = [[CMEditApi alloc] init];
// Composite two images together precisely
[apiInstance editCompositePreciseWithBaseImage:baseImage
layeredImage:layeredImage
top:top
bottom:bottom
left:left
right:right
width:width
height:height
completionHandler: ^(NSData* output, NSError* error) {
if (output) {
NSLog(@"%@", output);
}
if (error) {
NSLog(@"Error calling CMEditApi->editCompositePrecise: %@", error);
}
}];
Add the Ruby client to your Gemfile:
gem 'cloudmersive-image-recognition-api-client', '~> 2.0.4'
# load the gem
require 'cloudmersive-image-recognition-api-client'
# setup authorization
CloudmersiveImageRecognitionApiClient.configure do |config|
# Configure API key authorization: Apikey
config.api_key['Apikey'] = 'YOUR API KEY'
# Uncomment the following line to set a prefix for the API key, e.g. 'Bearer' (defaults to nil)
#config.api_key_prefix['Apikey'] = 'Bearer'
end
api_instance = CloudmersiveImageRecognitionApiClient::EditApi.new
base_image = File.new('/path/to/inputfile') # File | Image file to perform the operation on. Common file formats such as PNG, JPEG are supported.
layered_image = File.new('/path/to/inputfile') # File | Image to layer on top of the base image.
opts = {
top: 56, # Integer | Optional; Desired distance in pixels from the top of the base image to the top of the layered image.
bottom: 56, # Integer | Optional; Desired distance in pixels from the bottom of the base image to the bottom of the layered image.
left: 56, # Integer | Optional; Desired distance in pixels from the left side of the base image to the left side of the layered image.
right: 56, # Integer | Optional; Desired distance in pixels from the right side of the base image to the right side of the layered image.
width: 56, # Integer | Optional; Desired width of the layered image in pixels. Leave height empty or 0 to automatically scale the image proportionally.
height: 56 # Integer | Optional; Desired height of the layered image in pixels. Leave width empty or 0 to automatically scale the image proportionally.
}
begin
#Composite two images together precisely
result = api_instance.edit_composite_precise(base_image, layered_image, opts)
p result
rescue CloudmersiveImageRecognitionApiClient::ApiError => e
puts "Exception when calling EditApi->edit_composite_precise: #{e}"
end
SwagEditApi api = new SwagEditApi();
SwagClient client = api.getClient();
// Configure API key authorization: Apikey
ApiKeyAuth Apikey = (ApiKeyAuth) client.getAuthentication('Apikey');
Apikey.setApiKey('YOUR API KEY');
Map<String, Object> params = new Map<String, Object>{
'baseImage' => Blob.valueOf('Sample text file\nContents'),
'layeredImage' => Blob.valueOf('Sample text file\nContents'),
'top' => 56,
'bottom' => 56,
'left' => 56,
'right' => 56,
'width' => 56,
'height' => 56
};
try {
// cross your fingers
Blob result = api.editCompositePrecise(params);
System.debug(result);
} catch (Swagger.ApiException e) {
// ...handle your exceptions
}
Install libcurl in your C/C++ project:
libcurl/7.75.0
CURL *curl;
CURLcode res;
curl = curl_easy_init();
if(curl) {
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "POST");
curl_easy_setopt(curl, CURLOPT_URL, "https://api.cloudmersive.com/image/edit/composite/precise");
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1L);
curl_easy_setopt(curl, CURLOPT_DEFAULT_PROTOCOL, "https");
struct curl_slist *headers = NULL;
headers = curl_slist_append(headers, "top: <integer>");
headers = curl_slist_append(headers, "bottom: <integer>");
headers = curl_slist_append(headers, "left: <integer>");
headers = curl_slist_append(headers, "right: <integer>");
headers = curl_slist_append(headers, "width: <integer>");
headers = curl_slist_append(headers, "height: <integer>");
headers = curl_slist_append(headers, "Content-Type: multipart/form-data");
headers = curl_slist_append(headers, "Apikey: YOUR-API-KEY-HERE");
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers);
curl_mime *mime;
curl_mimepart *part;
mime = curl_mime_init(curl);
part = curl_mime_addpart(mime);
curl_mime_name(part, "baseImage");
curl_mime_filedata(part, "/path/to/file");
part = curl_mime_addpart(mime);
curl_mime_name(part, "layeredImage");
curl_mime_filedata(part, "/path/to/file");
curl_easy_setopt(curl, CURLOPT_MIMEPOST, mime);
res = curl_easy_perform(curl);
curl_mime_free(mime);
}
curl_easy_cleanup(curl);
curl --location --request POST 'https://api.cloudmersive.com/image/edit/composite/precise' \
--header 'top: <integer>' \
--header 'bottom: <integer>' \
--header 'left: <integer>' \
--header 'right: <integer>' \
--header 'width: <integer>' \
--header 'height: <integer>' \
--header 'Content-Type: multipart/form-data' \
--header 'Apikey: YOUR-API-KEY-HERE' \
--form 'baseImage=@"/path/to/file"' \
--form 'layeredImage=@"/path/to/file"'
import Foundation
#if canImport(FoundationNetworking)
import FoundationNetworking
#endif
var semaphore = DispatchSemaphore (value: 0)
let parameters = [
[
"key": "baseImage",
"src": "/path/to/file",
"type": "file"
],
[
"key": "layeredImage",
"src": "/path/to/file",
"type": "file"
]] as [[String : Any]]
let boundary = "Boundary-\(UUID().uuidString)"
var body = ""
var error: Error? = nil
for param in parameters {
if param["disabled"] == nil {
let paramName = param["key"]!
body += "--\(boundary)\r\n"
body += "Content-Disposition:form-data; name=\"\(paramName)\""
if param["contentType"] != nil {
body += "\r\nContent-Type: \(param["contentType"] as! String)"
}
let paramType = param["type"] as! String
if paramType == "text" {
let paramValue = param["value"] as! String
body += "\r\n\r\n\(paramValue)\r\n"
} else {
let paramSrc = param["src"] as! String
let fileData = try NSData(contentsOfFile:paramSrc, options:[]) as Data
let fileContent = String(data: fileData, encoding: .utf8)!
body += "; filename=\"\(paramSrc)\"\r\n"
+ "Content-Type: \"content-type header\"\r\n\r\n\(fileContent)\r\n"
}
}
}
body += "--\(boundary)--\r\n";
let postData = body.data(using: .utf8)
var request = URLRequest(url: URL(string: "https://api.cloudmersive.com/image/edit/composite/precise")!,timeoutInterval: Double.infinity)
request.addValue("<integer>", forHTTPHeaderField: "top")
request.addValue("<integer>", forHTTPHeaderField: "bottom")
request.addValue("<integer>", forHTTPHeaderField: "left")
request.addValue("<integer>", forHTTPHeaderField: "right")
request.addValue("<integer>", forHTTPHeaderField: "width")
request.addValue("<integer>", forHTTPHeaderField: "height")
request.addValue("multipart/form-data", forHTTPHeaderField: "Content-Type")
request.addValue("YOUR-API-KEY-HERE", forHTTPHeaderField: "Apikey")
request.addValue("multipart/form-data; boundary=\(boundary)", forHTTPHeaderField: "Content-Type")
request.httpMethod = "POST"
request.httpBody = postData
let task = URLSession.shared.dataTask(with: request) { data, response, error in
guard let data = data else {
print(String(describing: error))
semaphore.signal()
return
}
print(String(data: data, encoding: .utf8)!)
semaphore.signal()
}
task.resume()
semaphore.wait()
This code snippet uses the built-in JavaScript XHR request capability
Run this command to install jQuery:
bower install jquery
var data = new FormData();
data.append("baseImage", fileInput.files[0], "file");
data.append("layeredImage", fileInput.files[0], "file");
var xhr = new XMLHttpRequest();
xhr.withCredentials = true;
xhr.addEventListener("readystatechange", function() {
if(this.readyState === 4) {
console.log(this.responseText);
}
});
xhr.open("POST", "https://api.cloudmersive.com/image/edit/composite/precise");
xhr.setRequestHeader("top", "<integer>");
xhr.setRequestHeader("bottom", "<integer>");
xhr.setRequestHeader("left", "<integer>");
xhr.setRequestHeader("right", "<integer>");
xhr.setRequestHeader("width", "<integer>");
xhr.setRequestHeader("height", "<integer>");
xhr.setRequestHeader("Apikey", "YOUR-API-KEY-HERE");
xhr.send(data);
var form = new FormData();
form.append("baseImage", fileInput.files[0], "file");
form.append("layeredImage", fileInput.files[0], "file");
var settings = {
"url": "https://api.cloudmersive.com/image/edit/composite/precise",
"method": "POST",
"timeout": 0,
"headers": {
"top": "<integer>",
"bottom": "<integer>",
"left": "<integer>",
"right": "<integer>",
"width": "<integer>",
"height": "<integer>",
"Content-Type": "multipart/form-data",
"Apikey": "YOUR-API-KEY-HERE"
},
"processData": false,
"mimeType": "multipart/form-data",
"contentType": false,
"data": form
};
$.ajax(settings).done(function (response) {
console.log(response);
});
package main
import (
"fmt"
"bytes"
"mime/multipart"
"os"
"path/filepath"
"io"
"net/http"
"io/ioutil"
)
func main() {
url := "https://api.cloudmersive.com/image/edit/composite/precise"
method := "POST"
payload := &bytes.Buffer{}
writer := multipart.NewWriter(payload)
file, errFile1 := os.Open("/path/to/file")
defer file.Close()
part1,
errFile1 := writer.CreateFormFile("baseImage",filepath.Base("/path/to/file"))
_, errFile1 = io.Copy(part1, file)
if errFile1 != nil {
fmt.Println(errFile1)
return
}
file, errFile2 := os.Open("/path/to/file")
defer file.Close()
part2,
errFile2 := writer.CreateFormFile("layeredImage",filepath.Base("/path/to/file"))
_, errFile2 = io.Copy(part2, file)
if errFile2 != nil {
fmt.Println(errFile2)
return
}
err := writer.Close()
if err != nil {
fmt.Println(err)
return
}
client := &http.Client {
}
req, err := http.NewRequest(method, url, payload)
if err != nil {
fmt.Println(err)
return
}
req.Header.Add("top", "<integer>")
req.Header.Add("bottom", "<integer>")
req.Header.Add("left", "<integer>")
req.Header.Add("right", "<integer>")
req.Header.Add("width", "<integer>")
req.Header.Add("height", "<integer>")
req.Header.Add("Content-Type", "multipart/form-data")
req.Header.Add("Apikey", "YOUR-API-KEY-HERE")
req.Header.Set("Content-Type", writer.FormDataContentType())
res, err := client.Do(req)
if err != nil {
fmt.Println(err)
return
}
defer res.Body.Close()
body, err := ioutil.ReadAll(res.Body)
if err != nil {
fmt.Println(err)
return
}
fmt.Println(string(body))
}