Skip to content

Commit

Permalink
Toupetek AFW suppot auto direction spinning and some improvement.
Browse files Browse the repository at this point in the history
* Support auto direction spinning of filter wheel.
* Add debug control.
* Initialize TargetFilter when reconnect to device.
  • Loading branch information
jctk committed Jul 22, 2024
1 parent d455a98 commit 5790f82
Show file tree
Hide file tree
Showing 2 changed files with 40 additions and 1 deletion.
33 changes: 32 additions & 1 deletion indi-toupbase/indi_toupwheel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,7 @@ void ToupWheel::ISGetProperties(const char *dev)
{
INDI::FilterWheel::ISGetProperties(dev);
defineProperty(SlotsSP);
defineProperty(SpinningDirectionSP);
}

//////////////////////////////////////////////////////////////////////////////////////////////////
Expand All @@ -83,6 +84,9 @@ bool ToupWheel::initProperties()
{
INDI::FilterWheel::initProperties();

// Add Debug Control.
addDebugControl();

VersionTP[TC_FW_VERSION].fill("FIRMWARE", "Firmware", nullptr);
VersionTP[TC_HW_VERSION].fill("HARDWARE", "Hardware", nullptr);
VersionTP[TC_REV].fill("REVISION", "Revision", nullptr);
Expand Down Expand Up @@ -118,10 +122,18 @@ bool ToupWheel::updateProperties()
IUSaveText(&VersionTP[TC_REV], tmpBuffer);

defineProperty(VersionTP);

SpinningDirectionSP[TCFW_SD_CLOCKWISE].fill("CLOCKWISE", "Clockwise", ISS_ON);
SpinningDirectionSP[TCFW_SD_AUTO].fill("AUTO", "Auto Direction", ISS_OFF);
SpinningDirectionSP.fill(getDeviceName(), "SPINNINGDIRECTION", "Spinning Direction", FILTER_TAB, IP_RW, ISR_1OFMANY, 0, IPS_IDLE);
SpinningDirectionSP.load();

defineProperty(SpinningDirectionSP);
}
else
{
deleteProperty(VersionTP);
deleteProperty(SpinningDirectionSP);
}

return true;
Expand Down Expand Up @@ -149,6 +161,7 @@ bool ToupWheel::Connect()
FilterSlotN[0].max = slot;

FP(put_Option(m_Handle, CP(OPTION_FILTERWHEEL_SLOT), slot));
TargetFilter = 1; // if desconnected during spinning, TargetFilter must be initialize when reconnect.
SelectFilter(0);

LOGF_INFO("%s is connected.", getDeviceName());
Expand All @@ -174,6 +187,8 @@ void ToupWheel::TimerHit()

QueryFilter();

LOGF_DEBUG("TimerHit: CurrentFilter=%d, TargetFilter=%d", CurrentFilter, TargetFilter);

if (CurrentFilter != TargetFilter)
{
SetTimer(getCurrentPollingPeriod());
Expand Down Expand Up @@ -203,6 +218,21 @@ bool ToupWheel::ISNewSwitch(const char *dev, const char *name, ISState *states,
saveConfig(SlotsSP);
return true;
}
else if (SpinningDirectionSP.isNameMatch(name))
{
SpinningDirectionSP.update(states, names, n);
SpinningDirectionSP.setState(IPS_OK);
SpinningDirectionSP.apply();

auto currentSpinningDirection = SpinningDirectionSP.findOnSwitchIndex();
if (currentSpinningDirection == TCFW_SD_AUTO)
SpinningDirection = 0x100; // auto direction spinning
else
SpinningDirection = 0; // clockwise spinning

saveConfig(SpinningDirectionSP);
return true;
}
}

return INDI::FilterWheel::ISNewSwitch(dev, name, states, names, n);
Expand All @@ -213,7 +243,7 @@ bool ToupWheel::ISNewSwitch(const char *dev, const char *name, ISState *states,
//////////////////////////////////////////////////////////////////////////////////////////////////
bool ToupWheel::SelectFilter(int targetFilter)
{
HRESULT rc = FP(put_Option(m_Handle, CP(OPTION_FILTERWHEEL_POSITION), targetFilter - 1));
HRESULT rc = FP(put_Option(m_Handle, CP(OPTION_FILTERWHEEL_POSITION), SpinningDirection | (targetFilter - 1)));
if (FAILED(rc))
{
LOGF_ERROR("Failed to select filter wheel %d. %s", targetFilter, errorCodes(rc).c_str());
Expand Down Expand Up @@ -251,5 +281,6 @@ bool ToupWheel::saveConfigItems(FILE * fp)
INDI::FilterWheel::saveConfigItems(fp);

SlotsSP.save(fp);
SpinningDirectionSP.save(fp);
return true;
}
8 changes: 8 additions & 0 deletions indi-toupbase/indi_toupwheel.h
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,14 @@ class ToupWheel : public INDI::FilterWheel
SLOTS_8
};

INDI::PropertySwitch SpinningDirectionSP {2};
enum
{
TCFW_SD_CLOCKWISE,
TCFW_SD_AUTO
};
int SpinningDirection = 0;

THAND m_Handle { nullptr };
const XP(DeviceV2) *m_Instance;
};

0 comments on commit 5790f82

Please sign in to comment.