//创建新的大漠对象Idmsoft*InitNewDm(){Idmsoft*m_dm=NULL;//COleVarianttemp1,temp2;boolm_bInit=false;//下面直接加载dll创建对象,避免进行注册文件typedefHRESULT(__stdcall*pfnGCO)(REFCLSID,REFIID,void**);pfnGCOfnGCO=NULL;HINSTANCEhdllInst=LoadLibrary("dm.dll");fnGCO=(pfnGCO)GetProcAddress(hdllInst,"DllGetClassObject");if(fnGCO!=0){IClassFactory*pcf=NULL;HRESULThr=(fnGCO)(__uuidof(dmsoft),IID_IClassFactory,(void**)&pcf;);if(SUCCEEDED(hr)&&(pcf!=NULL)){hr=pcf->CreateInstance(NULL,__uuidof(Idmsoft),(void**)&m_dm);if((SUCCEEDED(hr)&&(m_dm!=NULL))==FALSE)returnfalse;}pcf->Release();m_bInit=true;}elsem_bInit=false;returnm_dm;};
2025/4/26 18:02:08 73.09MB VC++ 免注册 VS2017免注册 免注册
1
最近搜索了些在内存中转换图片格式的东西,比如截屏后的bmp图片在内存中转为jpg数据流,你可以通过socket发送这段jpg内存数据流,同时,你也可以通过内存数据流逆转换。
通过DibFile.h里面的两个函数完成(用的是Gdi+库):Bitmap*CreateBitmapFromMemory(constvoid*buf,size_tsize);void*SaveBitmapToMemory(Bitmap*image,void**outbuf,size_t*size,size_tCodecIndex=0,ULONGquality=50);说明:CodecIndex取值0-4,分别对应转换为jpg、bmp、gif、png、tiff格式,当为0时,参数quality有用,表示转换jpg的质量,取值0-100,数值越小,压缩比越大。
注意:outbuf为指针的指针,会在内部malloc内存,以保存转换后的图片数据流。
虽然此软件中没用到这两个函数,但是测试通过。
你可以进行如下测试:把jpg图片以二进制数据读到内存中,然后通过CreateBitmapFromMemory函数构建Bitmap,然后再SaveBitmapToMemory转换为另一段内存中,把这段内存以二进制数据存入文件,并用其他看图软件打开保存后的图片。
其他说明:此软件在先前版本的基础上修正两处Bug:1.保存图片时,若文件名含有点,会保存失败;
2.若在浏览图片时,另存图片后,滚动滚轮显示未知格式图片。
加入一个功能:保存为jpg图片时,可以选择图片质量。
有问题联系:hastings1986@163.com
1
注意:实验报告不全,参考价值:函数实现。
1.1用C++实现复数类,并为其定义必要的运算符。
structComplex{doublereal_;doubleimage_;Complex(void);Complex(doubleconst&real);Complex(doubleconst&real,doubleconst&imag);Complex(Complexconst&v);Complexoperator+(Complexconst&a)const;Complexoperator-(Complexconst&a)const;Complexoperator*(Complexconst&a)const;Complexoperator/(intn)const;……};1.2voidfft(Comples*dst,Complex*src,intp);快速傅里叶变换。
求复数数组src[0,2p)的傅里叶变换,结果存放在dst[0,2p)中。
1.3voidifft(Complex*dst,Complex*src,intp);快速傅里叶逆变换。
求复数数组src[0,2p)的逆傅里叶变换,结果存放在dst[0,2p)中。
1.4利用快速傅里叶变换计算长整数乘法。
typedefstd::vectorInteger;voidmultiply(Integer*rst,Integerconst&a,Integerconst&b);假设向量a[0,n)表示一个长整数:其中2≤β≤256为基底,函数将两个长整数a,b相乘,结果放在*rst向量中。
利用上面的长整数乘法程序计算结果 (123456789ABCDEF)16256^500×(FEDCBA987654321)16256^500 (987654321)1010^800×(123456789)1010^800
2025/4/6 5:17:12 22KB 北邮 数值 符号计算
1
intmain(void){SystemInit();delay_init();//延时函数初始化NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//设置NVIC中断分组2:2位抢占优先级,2位响应优先级uart_init(115200);//串口初始化为115200LED_Init();//LED端口初始化KEY_Init();//初始化与按键连接的硬件接口while(1){TIM3_PWM_Init(900,600,300,0);//arr=900;
四路PWM占空比分别为900/900、600/900、300/900、0/900}}
2025/3/10 19:02:51 2.29MB STM32 四路PWM
1
#pragmamark-拨打电话+(void)makePhoneCallWithTelNumber:(NSString*)tel;#pragmamark-判断手机号码的运营商类型+(NSString*)judgePhoneNumTypeOfMobileNum:(NSString*)mobileNum;#pragmamark-将时间转换成时间戳/***时间戳:指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数。
*/+(NSString*)timeStringIn
2025/3/3 20:58:57 5.09MB OC 工具类 封装 Extension
1
带移植说明的xmodem源码(STM32)//移植时,需要修改该函数//串口收发,实用查询方式。
voidxm_port_write(uint8*ch){ while(USART_GetFlagStatus(USART1,USART_FLAG_TXE)==RESET); USART1->DR=*ch;}//串口接收函数,需要移植sint8xm_port_read(uint8*ch){ if(USART_GetFlagStatus(USART1,USART_IT_RXNE)!=RESET) { *ch=USART_ReceiveData(USART1); return1; } return0;}//在定时中断里调用该函数//定时时间5msvoidxm_timer(void){ xmodem_timeout++;}
2025/1/29 3:13:31 4KB xmodem 源码 代码 移植
1
c语言实现的模板,实现方法是使用void指针和size包括listqueuestack三种
2025/1/13 2:05:28 4KB c语言 模板 list queue
1
voidxunji();voidkong_zhi(uchara0,uchara1,uchara2,uchara3);unsignedintbuf=0;voiddelay(unsignedinti)//延时子函数{unsignedintj,k;for(j=0;j<i;j++)for(k=0;k<10;k++);}intmain(void){WDTCTL=WDTPW+WDTHOLD;//关看门狗TA0CCTL1=OUTMOD_7;//PWM复位/置位模式TA1CCTL1=OUTMOD_7;//计数上限值,计数到该值时计数器清零,输出置位TA0CCR0=0x0500;TA0CCR1=0x0000;TA1CCR0=0x0500;TA1CCR1=0x0000;//计数到该值时输出复位
2024/10/15 1:48:11 2KB msp430g2553 红外循迹小车
1
/**给view设置圆角@paramcorners圆角位置@paramcornerRadii圆角弧度*/-(void)setCorners:(UIRectCorner)cornerscornerRadii:(CGSize)cornerRadii;
2024/10/13 13:29:11 5.13MB OC 工具类 封装 Extension
1
该控件继承QWidget,实现了左右上下四种形式的坐标轴控件。
可以设置固定间隔或自动选择间隔可以设置最小间隔开放一个槽来动态调整坐标轴的范围处理了边缘刻度的显示/*************************************************************************版权所有(C)2012-2015,liang1057@yahoo.com.cn类声明:坐标轴控件************************************************************************//**@brief坐标轴控件**@details坐标轴控件只有刻度和数字,数字可以隐藏(用来显示其他需要显示的刻度值)*/classuiAxis:publicQWidget{Q_OBJECTpublic:/**@brief坐标轴类型**@details坐标轴类型*/enumAXISTYPE{LEFT_AXIS=0,TOP_AXIS,RIGHT_AXIS,BOTTOM_AXIS};/**@brief构造函数*/uiAxis(AXISTYPEtype=BOTTOM_AXIS,QWidget*parent=0);/**@brief析构函数*/~uiAxis(void);/**@brief设置坐标轴的范围*/voidsetScop(doubleminValue,doublemaxValue);/**@brief获取坐标轴的范围*/voidgetScop(double&minValue,double&maxValue);/**@brief获取坐标轴的范围*/doublegetMinValue();doublegetMaxValue();/**@brief设置坐标轴的类型*/voidsetAxisType(AXISTYPEtype);/**@brief坐标轴的类型*/AXISTYPEgetAxisType();/**@brief设置最小刻度(小刻度的最小间隔)*/voidsetMinInterval(doublevalue);/**@brief设置自动间隔*/voidsetAutoScale(boolval=true);/**@brief设置固定间隔*/voidsetSettedScale(boolval=true);/**@brief设置坐标轴的绘制范围,像素值*/voidsetBoundary(intleft,intright,inttop,intbottom);voidgetBoundary(int&left,int&right,int&top,int&bottom);
2024/8/15 19:23:02 4KB Qt 坐标轴
1
共 52 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡