C++ 读取图像的所有字节并使用C存储在字节数组中
我正在开发evolis Primasy打印机(卡片打印机)和UNIX SCO OpenServer 5.0.7。我正在用c语言开发一个程序,它打开一个套接字并通过套接字向打印机发送命令 我应该把一些文字和图像放在PVC卡上,然后打印出来。 现在我用Java开发了第一段代码:C++ 读取图像的所有字节并使用C存储在字节数组中,c++,c,image,filesystems,C++,C,Image,Filesystems,我正在开发evolis Primasy打印机(卡片打印机)和UNIX SCO OpenServer 5.0.7。我正在用c语言开发一个程序,它打开一个套接字并通过套接字向打印机发送命令 我应该把一些文字和图像放在PVC卡上,然后打印出来。 现在我用Java开发了第一段代码: 从命令行获取参数 根据参数生成文本 把它们都放在它的位置上 生成png文件并将其保存到磁盘 现在我需要另一个程序将图像字节加载到字节数组(byte[]variable_name)中,通过套接字将其发送到打印机 我的套接字程序
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <netdb.h>
#include <netinet/in.h>
#include <sys/socket.h>
#define INVALID_SOCKET -1
#define SOCKET_ERROR -1
#define closesocket(s) close(s)
typedef int SOCKET;
typedef struct sockaddr_in SOCKADDR_IN;
typedef struct sockaddr SOCKADDR;
typedef struct in_addr IN_ADDR;
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#define PORT 9100 // the port client will be connecting to
#define MAXDATASIZE 10240 // max number of bytes we can get at once
char* ipdest;
int sockfd, numbytes;
char buf[MAXDATASIZE];
struct hostent *he;
struct sockaddr_in their_addr; // connector's address information
struct in_addr addr;
unsigned char[] load_file(char* filename){
unsigned char[] file_data=NULL;
//FILL file_data FROM FILE BYTES
return file_data;
}
void send_command(char* command, unsigned char* data[]){
if (connect(sockfd, (struct sockaddr *)&their_addr,sizeof their_addr) == -1) {
perror("connect");
exit(1);
}
if(data != NULL){
//MERGE DATA AND COMMAND AND THEN
//sprintf(buf,"\033%s\015", command);
}
else
sprintf(buf,"\033%s\015", command);
if (send(sockfd, buf, strlen(buf)+1, 0) == -1) {
perror("send");
exit(1);
}
shutdown(sockfd, 1);
if ((numbytes=recv(sockfd, buf, MAXDATASIZE-1, 0)) == -1) {
perror("recv");
exit(1);
}
buf[numbytes] = '\0';
printf("Received: %s\n",buf);
closesocket(sockfd);
}
int main(int argc, char *argv[])
{
if (argc != 2) {
fprintf(stderr,"printer ip address not defined!!\n");
exit(1);
}
ipdest = argv[1];
if ((!isalpha(ipdest[0])) || (he=gethostbyname(ipdest)) == NULL)
{
addr.s_addr = inet_addr(ipdest);
if (addr.s_addr == INADDR_NONE)
{
printf("The IPv4 address entered must be a legal address\n");
return 1;
}
else
he = gethostbyaddr((char *) &addr, 4, AF_INET);
}
if (he==NULL)
{
printf("Unable to open %s\n", ipdest );
exit(1);
}
if ((sockfd = socket(PF_INET, SOCK_STREAM, 0)) == -1) {
perror("socket");
exit(1);
}
their_addr.sin_family = AF_INET;
their_addr.sin_port = htons(PORT);
their_addr.sin_addr = *((struct in_addr *)he->h_addr);
memset(their_addr.sin_zero, '\0', sizeof their_addr.sin_zero);
//LOAD FILE AND SEND IT'S DATA TO PRINTER
send_command("Stt",load_file("res.png"));
return 0;
}
#包括
#包括
#包括
#包括
#包括
#包括
#定义无效的\u套接字-1
#定义套接字错误-1
#定义closesocket关闭
输入插座;
sockaddr_中的typedef结构sockaddr_;
类型定义结构sockaddr sockaddr;
地址中的typedef结构;
#包括
#包括
#包括
#定义端口9100//端口客户端将连接到
#定义MAXDATASIZE 10240//一次可以获取的最大字节数
char*ipdest;
int sockfd,numbytes;
char buf[MAXDATASIZE];
结构宿主*he;
结构sockaddr\u在其地址中;//连接器的地址信息
地址中的结构;
未签名字符[]加载文件(字符*文件名){
unsigned char[]file_data=NULL;
//从文件字节填充文件\u数据
返回文件和数据;
}
void send_命令(char*命令,未签名char*数据[]){
if(connect(sockfd,(struct sockaddr*)及其地址的大小)=-1){
perror(“连接”);
出口(1);
}
如果(数据!=NULL){
//合并数据和命令,然后
//sprintf(buf,“\033%s\015”,命令);
}
其他的
sprintf(buf,“\033%s\015”,命令);
如果(发送(sockfd,buf,strlen(buf)+1,0)=-1){
佩罗(“发送”);
出口(1);
}
停机(sockfd,1);
如果((numbytes=recv(sockfd,buf,MAXDATASIZE-1,0))=-1){
perror(“recv”);
出口(1);
}
buf[numbytes]='\0';
printf(“收到:%s\n”,buf);
闭合插座(sockfd);
}
int main(int argc,char*argv[])
{
如果(argc!=2){
fprintf(stderr,“未定义打印机ip地址!!\n”);
出口(1);
}
ipdest=argv[1];
if((!isalpha(ipdest[0]))| |(he=gethostbyname(ipdest))==NULL)
{
addr.s_addr=inet_addr(ipdest);
如果(addr.s_addr==INADDR_NONE)
{
printf(“输入的IPv4地址必须是合法地址\n”);
返回1;
}
其他的
he=gethostbyaddr((字符*)&addr,4,AF_INET);
}
if(he==NULL)
{
printf(“无法打开%s\n”,ipdest);
出口(1);
}
if((sockfd=socket(PF_INET,SOCK_STREAM,0))=-1){
佩罗(“插座”);
出口(1);
}
他们的地址sin家庭=家庭;
他们的地址sin港口=htons(港口);
他们的地址sin\u addr=*((地址中的结构)he->h\u addr);
memset(他们的地址sin\u zero,“\0”,他们的地址sin\u zero的大小);
//加载文件并将其数据发送到打印机
发送命令(“Stt”,加载文件(“res.png”);
返回0;
}
我有一个名为load_file()的方法,它应该加载文件字节,但是如何加载呢?
加载文件并将其数据传递给send_命令方法后,我应该将其数据与代码中解释的命令合并。在此处使用指针,而不是“unsigned char[]”,您可以将其传递给“send_命令”填充后我假设您还不知道您的卡片打印机是如何工作的,因此我认为您应该首先知道如何支持PNG格式。如果您的打印机类型有手册、API或开源驱动程序,则可以这样做。一旦您知道如何使用,您就可以使用下面的load_文件代码,然后创建另一个“转换”代码,该代码将转换load_文件中的简单字节数组 加载\u文件:
FILE *fp;
fp= fopen("res.png", "rb");
fseek(fp, 0, SEEK_END);
length= ftell(fp);
rewind(fp);
file_data= (char *)malloc((length+1)*sizeof(char));
fread(file_data, length, 1, fp);
return file_data
发送命令:
if(data != NULL){
//do the transformation here
transform(data);
}
你说什么?您需要一个
位图
格式的图像(无需库即可轻松阅读)或libPNG、ImageMagick等库。。阅读它。可能是离题了,但我正在寻找Evolis Primary的SDK文档。我猜询问者已经知道了。我在哪里可以找到这个?谢谢,我知道它是如何工作的,现在我知道它只能打印位图,比很多;)哦,好的。没问题。:)