Skip to content

Commit

Permalink
Merge pull request micro-manager#472 from franz-xaver/main
Browse files Browse the repository at this point in the history
FRE / excelitas pco gmbh / 26.06.2024 / added 48bit RGB
  • Loading branch information
marktsuchida authored Jun 28, 2024
2 parents d3a475b + a9bb2fe commit 1ee1bf7
Showing 1 changed file with 61 additions and 16 deletions.
77 changes: 61 additions & 16 deletions DeviceAdapters/PCO_Generic/MicroManager.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ const char* g_CameraDeviceName = "pco_camera";
const char* g_PixelType_8bit = "8bit";
const char* g_PixelType_16bit = "16bit";
const char* g_PixelType_RGB32bit = "RGB 32bit";
const char* g_PixelType_RGB48bit = "RGB 48bit";

const char* g_TimeStamp_No = "No stamp";
const char* g_TimeStamp_B = "Binary";
Expand Down Expand Up @@ -1008,8 +1009,10 @@ int CPCOCam::OnPixelType(MM::PropertyBase* pProp, MM::ActionType eAct)
pixelDepth_ = 2;
else if(pixType.compare(g_PixelType_8bit) == 0)
pixelDepth_ = 1;
else if(pixType.compare(g_PixelType_RGB32bit) == 0)
else if (pixType.compare(g_PixelType_RGB32bit) == 0)
pixelDepth_ = 4;
else if (pixType.compare(g_PixelType_RGB48bit) == 0)
pixelDepth_ = 6;
else
{
return DEVICE_INTERNAL_INCONSISTENCY;
Expand All @@ -1022,8 +1025,10 @@ int CPCOCam::OnPixelType(MM::PropertyBase* pProp, MM::ActionType eAct)
pProp->Set(g_PixelType_8bit);
else if(pixelDepth_ == 2)
pProp->Set(g_PixelType_16bit);
else if(pixelDepth_ == 4)
else if (pixelDepth_ == 4)
pProp->Set(g_PixelType_RGB32bit);
else if (pixelDepth_ == 6)
pProp->Set(g_PixelType_RGB48bit);
else
{
return DEVICE_INTERNAL_INCONSISTENCY;
Expand Down Expand Up @@ -1380,8 +1385,12 @@ int CPCOCam::Initialize()
pixTypes.push_back(g_PixelType_16bit);
pixTypes.push_back(g_PixelType_8bit);

if(m_pCamera->GetCCDCol(0))
if (m_pCamera->GetCCDCol(0))
{
pixTypes.push_back(g_PixelType_RGB32bit);
//pixTypes.push_back(g_PixelType_RGB48bit); // Not possible up to now 07/22
// Also GetImage does not convert to 48bit rgb, just 32bit rgb
}

nRet = SetAllowedValues(MM::g_Keyword_PixelType, pixTypes);
if(nRet != DEVICE_OK)
Expand Down Expand Up @@ -1663,10 +1672,14 @@ unsigned CPCOCam::GetBitDepth() const
{
return m_pCamera->GetBitsPerPixel();
}
else if(img_.Depth() == 4)
else if (img_.Depth() == 4)
{
return 8;
}
else if (img_.Depth() == 6)
{
return 16;
}
else
{
return 0; // should not happen
Expand Down Expand Up @@ -1746,9 +1759,9 @@ const unsigned char* CPCOCam::GetBuffer(int ibufnum)
ppic8 += iadd;
}
}
else if(img_.Depth() == 4)
else if (img_.Depth() == 4)
{
if(m_bDoAutoBalance)
if (m_bDoAutoBalance)
{
m_pCamera->SetLutMinMax(TRUE, TRUE);
m_pCamera->AutoBalance(0, 0, 0, 0, 0);
Expand All @@ -1757,28 +1770,60 @@ const unsigned char* CPCOCam::GetBuffer(int ibufnum)
m_pCamera->Convert(ibufnum);
iw = img_.Width();
ih = img_.Height();
unsigned char *pchar;
unsigned char *ppic8, *ph;
unsigned char* pchar;
unsigned char* ppic8, * ph;
int iadd;

ppic8 = m_pCamera->GetPic8c();

iadd = (iw * 3) % 4;
if(iadd != 0)
if (iadd != 0)
iadd = 4 - iadd;
pchar = const_cast<unsigned char*>(img_.GetPixelsRW());
for(int y = 0; y < ih; y++)
for (int y = 0; y < ih; y++)
{
ph = &ppic8[y*(iw * 3 + iadd)];
for(int x = 0; x < iw; x++)
ph = &ppic8[y * (iw * 3 + iadd)];
for (int x = 0; x < iw; x++)
{
*pchar++ = (unsigned char) *ph++;
*pchar++ = (unsigned char) *ph++;
*pchar++ = (unsigned char) *ph++;
*pchar++ = (unsigned char)*ph++;
*pchar++ = (unsigned char)*ph++;
*pchar++ = (unsigned char)*ph++;
*pchar++ = 0;
}
}
}
else if (img_.Depth() == 6)
{
if (m_bDoAutoBalance)
{
m_pCamera->SetLutMinMax(TRUE, TRUE);
m_pCamera->AutoBalance(0, 0, 0, 0, 0);
m_bDoAutoBalance = FALSE;
}
m_pCamera->Convert(ibufnum);
iw = img_.Width();
ih = img_.Height();
unsigned short* pchar;
unsigned char* ppic8, * ph;
int iadd;

ppic8 = m_pCamera->GetPic8c();

iadd = (iw * 3) % 4;
if (iadd != 0)
iadd = 4 - iadd;
pchar = (unsigned short*)(img_.GetPixelsRW());
for (int y = 0; y < ih; y++)
{
ph = &ppic8[y * (iw * 3 + iadd)];
for (int x = 0; x < iw; x++)
{
*pchar++ = (unsigned char)*ph++;
*pchar++ = (unsigned char)*ph++;
*pchar++ = (unsigned char)*ph++;
}
}
}

if(nErr != 0)
return 0;
Expand Down Expand Up @@ -2165,7 +2210,7 @@ int CPCOCam::ResizeImageBuffer()
m_iHeight = nHeight;
}

if(!(pixelDepth_ == 1 || pixelDepth_ == 2 || pixelDepth_ == 4))
if(!(pixelDepth_ == 1 || pixelDepth_ == 2 || pixelDepth_ == 4 || pixelDepth_ == 6))
return -1;
img_.Resize(nWidth, nHeight, pixelDepth_);
SetSizes(nWidth, nHeight, pixelDepth_);
Expand Down

0 comments on commit 1ee1bf7

Please sign in to comment.