黑白照片如何变彩色?亲测好用的方法分享

00652d03a75b1e2a1687a5f16e5e7d84.jpeg

小伙伴们家里会有以前的黑白照片吗?由于以前的摄像技术还不那么发达,因此照片普遍都是黑白色的。小伙伴们有过给黑白照片上色的想法吗?随着现在科技的不断发展,连给黑白照片还原成彩色的操作都能做到了。那怎么把黑白照片还原成彩色呢?其实我们使用一些软件就可以实现这个操作,下面我就来为大家分享几种不错的还原方法。

b7fd4f9d27c4e3551feb2128c6eb4ede.jpeg

方法一:使用Styler APP来为黑白照片还原彩色

可能有一些小伙伴没有听说过这款软件,这是一款可以为图片添加各种酷炫滤镜的图片特效类APP。我经常都会使用这款软件,来为图片进行一些简单的编辑处理操作。下面我们就来看看它是怎么为黑白照片还原颜色的吧。

【还原步骤】

步骤一:打开手机中的这款APP后,点击【工具】下的【黑白上色】功能。

5c5bf012baf7cb9db5b09aeff68aa869.jpeg

步骤二:将需要还原彩色的黑白照片导入进软件后,软件就会自动为黑白照片进行上色操作了。

8eeb5f7178e6e2e33203486d72f2e570.jpeg

方法二:使用WPS来为黑白照片还原彩色

说到WPS,我们经常都会使用它来进行文档编辑的操作。其实它为了方便我们制作文档,也推出了许多实用的图片编辑功能,其中就有能为黑白照片上色的功能。

【还原步骤】

将黑白照片插入文档后,点击【…】,接着选择【画质修复】功能,就可以为黑白照片上色了。

51a907987dba651bfcc09791cac9fdec.jpeg

看完这篇文章,大家都学会怎么把黑白照片还原成彩色了吗?如果你们在操作上还有遇到什么不懂的地方,欢迎随时向我提问。

if(strPathName == "") return false; BITMAPFILEHEADER * pBFH; BITMAPINFOHEADER * pBIH; CFile file(strPathName,CFile::modeCreate | CFile::modeNoTruncate | CFile::modeRead); DWORD filelength = file.GetLength(); // 分配一块内存用于装入图象数据 if(m_hDib!=NULL) ::GlobalFree(m_hDib); m_hDib = :: GlobalAlloc(GMEM_MOVEABLE | GMEM_ZEROINIT,filelength); if(m_hDib==NULL) { return (FALSE); } m_pDib = (BYTE *)::GlobalLock(m_hDib); if(m_pDib==NULL) { ::GlobalFree(m_hDib); return (FALSE); } // 将图象数据读入内存 file.Read(m_pDib,(UINT)filelength); file.Close(); // 读入头信息 pBFH = (BITMAPFILEHEADER *) m_pDib; pBIH = (BITMAPINFOHEADER *) (m_pDib+sizeof(BITMAPFILEHEADER)); WORD bfType = pBFH->bfType; if(bfType!=19778) // "BM"标志 { AfxMessageBox("Not a valid BMP image!"); return FALSE; } //得到位图信息 m_nWidth = (int)pBIH->biWidth; m_nHeight = (int)pBIH->biHeight; m_nBits = (int)pBIH->biBitCount; m_nColors = (int)pBIH->biClrUsed; if(m_nColors == 0) { if(m_nBits <= 8) m_nColors = 1 << m_nBits; } m_strPathName = strPathName; // 载入调色板 m_Palette.DeleteObject(); if( m_nBits <= 8 ) m_nPaletteInBytes = m_nColors * sizeof( RGBQUAD ); if( m_nBits <= 8 ) { RGBQUAD *pRGBPalette; pRGBPalette = ( RGBQUAD * )&m_pDib[ sizeof( BITMAPFILEHEADER ) + sizeof( BITMAPINFOHEADER ) ]; LOGPALETTE *pLogPalette; pLogPalette = ( LOGPALETTE * )new char[ sizeof( LOGPALETTE ) + m_nColors * sizeof( PALETTEENTRY ) ]; pLogPalette->palVersion = 0x300; pLogPalette->palNumEntries = ( unsigned short )m_nColors; for(int i=0; i<m_nColors; i++ ) { pLogPalette->palPalEntry[ i ].peRed = pRGBPalette[ i ].rgbRed; pLogPalette->palPalEntry[ i ].peGreen = pRGBPalette[ i ].rgbGreen; pLogPalette->palPalEntry[ i ].peBlue = pRGBPalette[ i ].rgbBlue; pLogPalette->palPalEntry[ i ].peFlags = 0; } if( pLogPalette == NULL ) { ::GlobalUnlock( m_hDib ); return FALSE; } m_Palette.CreatePalette( pLogPalette ); delete[] pLogPalette; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值