diff options
| author | Andy Wortman <ixineeringeverywhere@gmail.com> | 2019-03-14 15:52:30 -0700 | 
|---|---|---|
| committer | Andy Wortman <ixineeringeverywhere@gmail.com> | 2019-03-14 15:52:30 -0700 | 
| commit | 9a607474bdd66dd716635cfed7f2c832c39b4523 (patch) | |
| tree | c5f65b4cecd6376a3b99646679f9714d5f9213a2 /include/qhy/ic16803.h | |
| parent | ac7604616ab2e44ad12a9d8d5dd90dec15feb5cc (diff) | |
add qhy headers.........
Diffstat (limited to 'include/qhy/ic16803.h')
| -rw-r--r-- | include/qhy/ic16803.h | 509 | 
1 files changed, 509 insertions, 0 deletions
| diff --git a/include/qhy/ic16803.h b/include/qhy/ic16803.h new file mode 100644 index 0000000..0d4ae42 --- /dev/null +++ b/include/qhy/ic16803.h @@ -0,0 +1,509 @@ +/*
 + QHYCCD SDK
 + 
 + Copyright (c) 2014 QHYCCD.
 + All Rights Reserved.
 + 
 + This program is free software; you can redistribute it and/or modify it
 + under the terms of the GNU General Public License as published by the Free
 + Software Foundation; either version 2 of the License, or (at your option)
 + any later version.
 + 
 + This program is distributed in the hope that it will be useful, but WITHOUT
 + ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 + FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 + more details.
 + 
 + You should have received a copy of the GNU General Public License along with
 + this program; if not, write to the Free Software Foundation, Inc., 59
 + Temple Place - Suite 330, Boston, MA  02111-1307, USA.
 + 
 + The full GNU General Public License is included in this distribution in the
 + file called LICENSE.
 + */
 +
 +/*!
 + * @file ic16803.h
 + * @brief IC16803 class define
 + */
 +
 +#include "qhybase.h"
 +
 +#ifndef __IC16803DEF_H__
 +#define __IC16803DEF_H__
 +
 +/**
 + * @brief IC16803 class define
 + *
 + * include all functions for IC16803
 + */
 +class IC16803:public QHYBASE
 +{
 +public:
 +    IC16803();
 +    ~IC16803();
 +  
 +    /**
 +     @fn uint32_t InitChipRegs(qhyccd_handle *h)
 +     @brief Init the registers and some other things
 +     @param h camera control handle
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t InitChipRegs(qhyccd_handle *h);
 +    
 +    /**
 +     @fn uint32_t IsChipHasFunction(CONTROL_ID id)
 +     @brief check the camera has the function or not
 +     @param id function id
 +     @return
 +     HAVE return QHYCCD_HAVE \n
 +     NOT HAVE return QHYCCD_NOTHAVE
 +     */
 +    uint32_t IsChipHasFunction(CONTROL_ID id);
 +        
 +    /**
 +     @fn uint32_t SetChipGain(qhyccd_handle *h,double gain)
 +     @brief set the gain to camera
 +     @param h camera control handle
 +     @param gain gain value
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t SetChipGain(qhyccd_handle *h,double gain);
 +    
 +    /**
 +     @fn uint32_t SetChipExposeTime(qhyccd_handle *h,double i)
 +     @brief set the expose time to camera
 +     @param h camera control handle
 +     @param i expose time value
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t SetChipExposeTime(qhyccd_handle *h,double i);
 +    
 +    /**
 +     @fn uint32_t SetChipSpeed(qhyccd_handle *h,uint32_t i)
 +     @brief set the transfer speed to camera
 +     @param h camera control handle
 +     @param i speed level
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t SetChipSpeed(qhyccd_handle *h,uint32_t i);
 +  
 +    /**
 +     @fn uint32_t SetChipOffset(qhyccd_handle *h,double offset)
 +     @brief set the camera offset
 +     @param h camera control handle
 +     @param offset offset value
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t SetChipOffset(qhyccd_handle *h,double offset);
 +    
 +    /**
 +     @fn uint32_t SetChipBinMode(qhyccd_handle *h,uint32_t wbin,uint32_t hbin)
 +     @brief set the camera offset
 +     @param h camera control handle
 +     @param wbin width bin
 +     @param hbin height bin
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t SetChipBinMode(qhyccd_handle *h,uint32_t wbin,uint32_t hbin);
 +    
 +    /**
 +     @fn uint32_t GetControlMinMaxStepValue(CONTROL_ID controlId,double *min,double *max,double *step)
 +     @brief get the min,max and step value for function
 +     @param controlId the control id
 +     @param min the min value for function
 +     @param max the max value for function
 +     @param step single step value for function
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t GetControlMinMaxStepValue(CONTROL_ID controlId,double *min,double *max,double *step);
 +    
 +    /**
 +     @fn double GetChipCoolTemp(qhyccd_handle *h)
 +     @brief get the current ccd/cmos temprature
 +     @param h camera control handle
 +     @return
 +     success return the current cool temprature \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    double GetChipCoolTemp(qhyccd_handle *h);
 +    
 +    /**
 +     @fn double GetChipCoolPWM()
 +     @brief get the current ccd/cmos temprature
 +     @return
 +     success return the current cool temprature \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    double GetChipCoolPWM();
 +    
 +    /**
 +     @fn uint32_t CorrectWH(uint32_t *w,uint32_t *h)
 +     @brief correct width and height if the setting width or height is not correct
 +     @param w set width
 +     @param h set height
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t CorrectWH(uint32_t *w,uint32_t *h);
 +    
 +    /**
 +     @fn double InitBIN11Mode(uint32_t x,uint32_t y,uint32_t xsize,uint32_t ysize)
 +     @brief init the bin11 mode setting
 +     @param x  the image top left x position
 +     @param y  the image top left y position
 +     @param xsize the image width
 +     @param ysize the image height
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t InitBIN11Mode(uint32_t x,uint32_t y,uint32_t xsize,uint32_t ysize);
 +    
 +    /**
 +     @fn double InitBIN22Mode(uint32_t x,uint32_t y,uint32_t xsize,uint32_t ysize)
 +     @brief init the bin22 mode setting
 +     @param x  the image top left x position
 +     @param y  the image top left y position
 +     @param xsize the image width
 +     @param ysize the image height
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t InitBIN22Mode(uint32_t x,uint32_t y,uint32_t xsize,uint32_t ysize);
 +
 +    /**
 +     @fn double InitBIN33Mode(uint32_t x,uint32_t y,uint32_t xsize,uint32_t ysize)
 +     @brief init the bin33 mode setting
 +     @param x  the image top left x position
 +     @param y  the image top left y position
 +     @param xsize the image width
 +     @param ysize the image height
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t InitBIN33Mode(uint32_t x,uint32_t y,uint32_t xsize,uint32_t ysize);
 +
 +    /**
 +     @fn double InitBIN44Mode(uint32_t x,uint32_t y,uint32_t xsize,uint32_t ysize)
 +     @brief init the bin44 mode setting
 +     @param x  the image top left x position
 +     @param y  the image top left y position
 +     @param xsize the image width
 +     @param ysize the image height
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t InitBIN44Mode(uint32_t x,uint32_t y,uint32_t xsize,uint32_t ysize);
 +    
 +   /** 
 +    @fn uint32_t SetChipResolution(qhyccd_handle *handle,uint32_t x,uint32_t y,uint32_t xsize,uint32_t ysize)
 +    @brief set camera ouput resolution
 +    @param handle camera control handle
 +    @param x the top left position x
 +    @param y the top left position y
 +    @param xsize the image width
 +    @param ysize the image height
 +    @return
 +    on success,return QHYCCD_SUCCESS\n
 +    another QHYCCD_ERROR code on other failures
 +    */
 +    uint32_t SetChipResolution(qhyccd_handle *handle,uint32_t x,uint32_t y,uint32_t xsize,uint32_t ysize);
 +    
 +    /**
 +     @fn uint32_t BeginSingleExposure(qhyccd_handle *h)
 +     @brief begin single exposure
 +     @param h camera control handle
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t BeginSingleExposure(qhyccd_handle *h);
 +    
 +    /**
 +     @fn uint32_t CancelExposing(qhyccd_handle *handle)
 +     @param handle camera control handle
 +     @return
 +     on success,return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t CancelExposing(qhyccd_handle *handle);
 +
 +    /**
 +     @fn uint32_t CancelExposingAndReadout(qhyccd_handle *h)
 +     @brief stop single exposure
 +     @param h camera control handle
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t CancelExposingAndReadout(qhyccd_handle *h);
 +    
 +    /**
 +     @fn uint32_t BeginLiveExposure(qhyccd_handle *h)
 +     @brief begin live exposure
 +     @param h camera control handle
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t BeginLiveExposure(qhyccd_handle *h);
 +    
 +    /**
 +     @fn uint32_t StopLiveExposure(qhyccd_handle *h)
 +     @brief stop live exposure
 +     @param h camera control handle
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t StopLiveExposure(qhyccd_handle *h);
 +    
 +    /**
 +     @fn uint32_t GetLiveFrame(qhyccd_handle *h,uint32_t *pW,uint32_t *pH,uint32_t * pBpp,uint32_t *pChannels,uint8_t *ImgData)
 +     @brief get live frame image data
 +     @param h camera control handle
 +     @param pW real width
 +     @param pH real height
 +     @param pBpp real depth bits
 +     @param pChannels real channels
 +     @param ImgData image data buffer
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t GetLiveFrame(qhyccd_handle *h,uint32_t *pW,uint32_t *pH,uint32_t * pBpp,uint32_t *pChannels,uint8_t *ImgData);
 +    
 +    /**
 +     @fn uint32_t AutoTempControl(qhyccd_handle *h,double ttemp)
 +     @brief auto temprature control
 +     @param h camera control handle
 +     @param ttemp target temprature(degree Celsius)
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t AutoTempControl(qhyccd_handle *h,double ttemp);
 +    
 +    /**
 +     @fn uint32_t SetChipCoolPWM(qhyccd_handle *h,double PWM)
 +     @brief set cool power
 +     @param h camera control handle
 +     @param PWM power(0-255)
 +     @return
 +     success return QHYCCD_SUCCESS \n
 +     another QHYCCD_ERROR code on other failures
 +     */
 +    uint32_t SetChipCoolPWM(qhyccd_handle *h,double PWM);
 +    
 +    /**
 +     @fn void ConvertDataBIN11(uint8_t * Data,uint32_t x, uint32_t y, uint16_t PixShift)
 +     @brief move the pixel raw data to correction position,and bin if need
 +     @param Data raw image data
 +     @param x image width
 +     @param y image height
 +     @param PixShift this is a way to fix the bad pixel data by the usb transfer
 +     */
 +    void ConvertDataBIN11(uint8_t * Data,uint32_t x, uint32_t y, uint16_t PixShift);
 +    
 +    /**
 +     @fn void ConvertDataBIN22(uint8_t * Data,uint32_t x, uint32_t y, uint16_t PixShift)
 +     @brief move the pixel raw data to correction position,and bin if need
 +     @param Data raw image data
 +     @param x image width
 +     @param y image height
 +     @param PixShift this is a way to fix the bad pixel data by the usb transfer
 +     */
 +    void ConvertDataBIN22(uint8_t * Data,uint32_t x, uint32_t y, uint16_t PixShift);
 + 
 +   /**
 +     @fn void ConvertDataBIN44(uint8_t * Data,uint32_t x, uint32_t y, uint16_t PixShift)
 +     @brief move the pixel raw data to correction position,and bin if need
 +     @param Data raw image data
 +     @param x image width
 +     @param y image height
 +     @param PixShift this is a way to fix the bad pixel data by the usb transfer
 +     */
 +    void ConvertDataBIN44(uint8_t * Data,uint32_t x, uint32_t y, uint16_t PixShift);
 +	 
 +    /**
 +      @fn uint32_t SetFocusSetting(qhyccd_handle *h,uint32_t focusCenterX, uint32_t focusCenterY)
 +      @brief Set the camera on focus mode
 +      @param h camera control handle
 +      @param focusCenterX
 +      @param focusCenterY
 +      @return
 +	  on success,return QHYCCD_SUCCESS \n
 +	  another QHYCCD_ERROR code on other failures
 +     */
 +     uint32_t SetFocusSetting(qhyccd_handle *h,uint32_t focusCenterX, uint32_t focusCenterY);
 +    /** @fn virtual uint32_t SetInterCamSerialParam(qhyccd_handle *h,uint32_t opt)
 +      @brief Set InterCam serial2 params
 +      @param h camera control handle
 +	  @param opt the param
 +      @return
 +	  on success,return QHYCCD_SUCCESS \n
 +
 +	  another QHYCCD_ERROR code on other failures
 +    */
 +     uint32_t SetInterCamSerialParam(qhyccd_handle *h,uint32_t opt);
 +
 +  /** @fn virtual uint32_t InterCamSerialTX(qhyccd_handle *h,char *buf,uint32_t length)
 +      @brief Send data to InterCam serial2
 +      @param h camera control handle
 +	  @param buf buffer for data
 +	  @param length the length to send
 +      @return
 +	  on success,return QHYCCD_SUCCESS \n
 +
 +	  another QHYCCD_ERROR code on other failures
 +    */
 +     uint32_t InterCamSerialTX(qhyccd_handle *h,char *buf,uint32_t length);
 +
 +
 +  /** @fn virtual uint32_t InterCamSerialRX(qhyccd_handle *h,char *buf)
 +      @brief Get data from InterCam serial2
 +      @param h camera control handle
 +	  @param buf buffer for data
 +      @return
 +	  on success,return the data number \n
 +
 +	  another QHYCCD_ERROR code on other failures
 +    */
 +	 uint32_t InterCamSerialRX(qhyccd_handle *h,char *buf);
 +
 +   /** @fn virtual uint32_t Send2OledFast(qhyccd_handle *h,char *buffer)
 +      @brief send data to show on InterCam's OLED
 +      @param h camera control handle
 +	  @param buffer buffer for data
 +      @return
 +	  on success,return QHYCCD_SUCCESS \n
 +	  another QHYCCD_ERROR code on other failures
 +    */
 +     uint32_t Send2OledFast(qhyccd_handle *h,uint8_t *buffer);
 +
 +	/** @fn uint32_t InterCamOledOnOff(qhyccd_handle *handle,uint8_t onoff)
 +      @brief turn off or turn on the InterCam's Oled
 +      @param handle camera control handle
 +	  @param onoff on or off the oled \n
 +	  1:on \n
 +	  0:off \n
 +      @return
 +	  on success,return QHYCCD_SUCCESS \n
 +	  another QHYCCD_ERROR code on other failures
 +    */
 +	 uint32_t InterCamOledOnOff(qhyccd_handle *handle,uint8_t onoff);
 +
 +	/** @fn uint32_t SetInterCamOledBrightness(qhyccd_handle *handle,uint8_t brightness)
 +      @brief send data to show on InterCam's OLED
 +      @param handle camera control handle
 +	  @param brightness the oled's brightness
 +      @return
 +	  on success,return QHYCCD_SUCCESS \n
 +	  another QHYCCD_ERROR code on other failures
 +    */
 +	 uint32_t SetInterCamOledBrightness(qhyccd_handle *handle,uint8_t brightness);
 +
 +     uint32_t SendFourLine2InterCamOled(qhyccd_handle *handle,char *messagetemp,char *messageinfo,char *messagetime,char *messagemode);
 +
 +	/** @fn uint32_t SendTwoLine2InterCamOled(qhyccd_handle *handle,char *messageTop,char *messageBottom)
 +      @brief spilit the message to two line,send to camera
 +      @param handle camera control handle
 +	  @param messageTop message for the oled's 1st line
 +	  @param messageBottom message for the oled's 2nd line
 +      @return
 +	  on success,return QHYCCD_SUCCESS \n
 +	  another QHYCCD_ERROR code on other failures
 +    */
 +	 uint32_t SendTwoLine2InterCamOled(qhyccd_handle *handle,char *messageTop,char *messageBottom);
 +
 +      /** 
 +      @fn uint32_t SendOneLine2InterCamOled(qhyccd_handle *handle,char *messageTop)
 +      @brief spilit the message to two line,send to camera
 +      @param handle camera control handle
 +      @param messageTop message for all the oled
 +      @return
 +      on success,return QHYCCD_SUCCESS \n
 +      another QHYCCD_ERROR code on other failures
 +      */  
 +      uint32_t SendOneLine2InterCamOled(qhyccd_handle *handle,char *messageTop);
 +
 +      /** 
 +      @fn uint32_t GetCameraStatus(qhyccd_handle *h,uint8_t *buf)
 +      @brief Get camera status
 +      @param h camera control handle
 +      @param buf camera's status save space
 +      @return
 +      on success,return the camera statu \n
 +      another QHYCCD_ERROR code on other failures
 +      */
 +      uint32_t GetCameraStatus(qhyccd_handle *h,uint8_t *buf);
 +
 +	 /** 
 +	  @fn uint32_t SendOrder2CFW(qhyccd_handle *handle,char *order,uint32_t length)
 +      @brief control color filter wheel 
 +      @param handle camera control handle
 +	  @param order order send to color filter wheel
 +	  @param length the order string length
 +	  @return
 +	  on success,return QHYCCD_SUCCESS \n
 +	  another QHYCCD_ERROR code on other failures
 +    */
 +	 uint32_t SendOrder2CFW(qhyccd_handle *handle,char *order,uint32_t length);
 +
 +	 /** 
 +	  @fn uint32_t GetCFWStatus(qhyccd_handle *handle,char *status)
 +      @brief get the color filter wheel status
 +      @param handle camera control handle
 +	  @param status the color filter wheel position status
 +	  @return
 +	  on success,return QHYCCD_SUCCESS \n
 +	  another QHYCCD_ERROR code on other failures
 +    */
 +	uint32_t GetCFWStatus(qhyccd_handle *handle,char *status);
 +
 +	 /** 
 +	  @fn uint32_t ControlShutter(qhyccd_handle *handle,uint8_t status)
 +      @brief control camera's shutter
 +      @param handle camera control handle
 +	  @param status the shutter status
 +	  @return
 +	  on success,return QHYCCD_SUCCESS \n
 +	  another QHYCCD_ERROR code on other failures
 +     */
 +	 uint32_t ControlShutter(qhyccd_handle *handle,uint8_t status);
 +
 +	 /** 
 +	  @fn uint32_t GetShutterStatus(qhyccd_handle *handle)
 +      @brief get the camera's shutter status 
 +      @param handle camera control handle
 +	  @return
 +	  on success,return status \n
 +	  another QHYCCD_ERROR code on other failures
 +     */
 +	 uint32_t GetShutterStatus(qhyccd_handle *handle);
 +
 +	 uint32_t GetHumidity(qhyccd_handle *handle,double *hd);
 +
 +	 uint32_t SetTrigerFunction(qhyccd_handle *handle,bool value);
 +};
 +#endif
 +
 | 
