最近使用NX二次開(kāi)發(fā),需要用到集列表,也就是SetList這個(gè)控件,然而網(wǎng)上相關(guān)的資料和范例實(shí)在是太少,有幸找到《NX二次開(kāi)發(fā)-BlockUI集列表的使用技巧》和《UG(NX)二次開(kāi)發(fā) BlockUI 集列表使用方法》,這兩篇文章,對(duì)我的幫助很大,但是因?yàn)槭褂玫木幊陶Z(yǔ)言不同(我使用的是c++),仍然遇到了很多困難,不過(guò)最終在我不斷的摸索和嘗試下,終于有個(gè)完整的使用流程,特此分享給需要的同學(xué),避免跟我一樣一下子不知道從何下手。
想快速獲取結(jié)果的可以直接看代碼,想看一下問(wèn)題的解決過(guò)程的,且聽(tīng)我娓娓道來(lái)。
對(duì)于集列表,它不同于一般的控件,一般的控件直接添加即可,而集列表則需要添加種子塊,那么種子塊如何添加呢,下面我將詳細(xì)說(shuō)明這個(gè)步驟。
項(xiàng)目原因,我就使用nx8.0的32位版本來(lái)做說(shuō)明,其他版本類似。
首先,打開(kāi)任意項(xiàng)目,然后打開(kāi)塊UI樣式編輯器,如下圖所示:
?新建或者打開(kāi)任意界面,并且添加集列表:
此時(shí)提示“錯(cuò)誤:缺少種子塊”。
我們需要新建或者使用已有的任意對(duì)話框dlx文件,并且在下方紅色方框位置填入文件名(dlx在同一目錄的情況下),如果種子塊在不同目錄,則使用種子塊dlx文件的全路徑。
此時(shí),錯(cuò)誤提示消失,并且自動(dòng)加入到主界面。
?
?在集列表中可以設(shè)置是否自動(dòng)展開(kāi)以及列數(shù)等。
以上是界面相關(guān),下面進(jìn)入代碼部分,這部分主要是我在前面兩篇文章的的幫助下摸索和嘗試出來(lái)的,特此分享關(guān)鍵代碼,項(xiàng)目原因部分不重要的代碼實(shí)現(xiàn)無(wú)法公開(kāi),可以自己考慮實(shí)現(xiàn),或者查閱資料,調(diào)用UG自帶的函數(shù)。
針對(duì)集列表,主要有兩個(gè)回調(diào)函數(shù),添加和刪除按鈕時(shí)的回調(diào)函數(shù),我無(wú)法直接找到相關(guān)的c++范例,不過(guò)后來(lái)我發(fā)現(xiàn),可以查看函數(shù)的聲明和參數(shù)來(lái)確定回調(diào)函數(shù)的樣式。
比如:對(duì)于集列表m_pListCurves,輸入set可以智能提示有如下回調(diào)函數(shù):
而我們需要的就是AddHandler和DelHandler,那么如何添加這兩個(gè)回調(diào)函數(shù)呢,我們可以按F12,進(jìn)去聲明看一下:
然后在AddCallback的地方再按下F12,此時(shí)就可以看到如下的聲明:
這代表著,這個(gè)回調(diào)函數(shù)是以int為返回值,以 NXOpen::BlockStyler::SetList *為參數(shù)類型的函數(shù),同理,在下方可以看到Del的回調(diào)函數(shù)樣式:
typedef NXOpen::Callback2<int, NXOpen::BlockStyler::SetList *, NXOpen::BlockStyler::UIBlock *> DeleteCallback;
形如:
// 集列表回調(diào)函數(shù)
int addCurve_cb(NXOpen::BlockStyler::SetList *);
int deleteCurve_cb(NXOpen::BlockStyler::SetList *, NXOpen::BlockStyler::UIBlock *);
于是,得到下面的代碼:
// 這是添加按鈕的
m_pListCurves->SetAddHandler(make_callback(this, &CAMFeatureAddCurveUI::addCurve_cb));
// 這是刪除按鈕的
m_pListCurves->SetDeleteHandler(make_callback(this, &CAMFeatureAddCurveUI::deleteCurve_cb));
供參考。
為了在點(diǎn)擊添加按鈕的時(shí)候,可以自動(dòng)有一些動(dòng)作,比如初始化界面等(這里說(shuō)一下,nx初始化界面一般是放在dialogShown_cb()中的,但是因?yàn)檫@個(gè)是作為list控件的種子塊,dialogShown_cb()并不會(huì)執(zhí)行,所以這種情況下的初始化應(yīng)該放在添加按鈕的回調(diào)函數(shù)中)。
代碼供參考:
int CAMFeatureAddCurveUI::addCurve_cb(NXOpen::BlockStyler::SetList *pList)
{
// 點(diǎn)擊添加按鈕的時(shí)候,會(huì)添加一個(gè)你設(shè)置的seedDlx的那個(gè)ui
UIBlock *pBlockUI = m_pListCurves->AddNewSet(true);
// 這個(gè)是設(shè)置顯示的文本,第一列是序號(hào),后面是的列自己設(shè)置即可
int nNewIndex = m_pListCurves->GetItems().size();
NXString stIndex = AUTUMOONString::to_string(nNewIndex).c_str();
stIndex = "曲線組" + stIndex;
std::vector<NXString> vContenInList;
vContenInList.push_back(stIndex);
m_pListCurves->SetItemText(pBlockUI, vContenInList);
// 針對(duì)控件的初始化
// 強(qiáng)轉(zhuǎn)成NXOpen.BlockStyler.CompositeBlock,類似一個(gè)UI的集合,里面可以添加很多ui
NXOpen::BlockStyler::CompositeBlock *compositeBlock = (NXOpen::BlockStyler::CompositeBlock *)pBlockUI;
// 分別查找對(duì)應(yīng)的控件
NXOpen::BlockStyler::UIBlock *edge_select0 = compositeBlock->FindBlock("edge_select0");
NXOpen::BlockStyler::UIBlock *enumCamMethod = compositeBlock->FindBlock("enumCamMethod");
NXOpen::BlockStyler::UIBlock *enumMaterialSide = compositeBlock->FindBlock("enumMaterialSide");
NXOpen::BlockStyler::UIBlock *doubleProcessDis = compositeBlock->FindBlock("doubleProcessDis");
NXOpen::BlockStyler::UIBlock *doubleSelToolDia = compositeBlock->FindBlock("doubleSelToolDia");
NXOpen::BlockStyler::UIBlock *toggleRough = compositeBlock->FindBlock("toggleRough");
NXOpen::BlockStyler::UIBlock *toggleFinish = compositeBlock->FindBlock("toggleFinish");
doubleSelToolDia->AUTUMOONBLock_SetDouble(63.0);
enumCamMethod->AUTUMOONBLock_SetEnum(0);
enumMaterialSide->AUTUMOONBLock_SetEnum(0);
edge_select0->Focus();
// 計(jì)算加工距離
Vector3d vec3d = m_pVectorZ->GetProperties()->GetVector("Vector");
AUTUMOONMathVector3d ivecUserZ(vec3d.X, vec3d.Y, vec3d.Z);
// 計(jì)算加工距離
double dProcessDistance =
CAMFeaRecognition::GetProcessDistanceEx(m_cfFeature.m_pvFaces, m_cfFeature.m_eCAMMachiningType, ivecUserZ);
doubleProcessDis->AUTUMOONBLock_SetDouble(dProcessDistance);
return 0;
}
其中的關(guān)鍵是獲取塊指針,用FindBlock來(lái)實(shí)現(xiàn)。
刪除功能的回調(diào)函數(shù),基本可以通用,如果你不需要進(jìn)行特別處理的話。
int CAMFeatureAddCurveUI::deleteCurve_cb(NXOpen::BlockStyler::SetList *pList, NXOpen::BlockStyler::UIBlock *pBlockUI)
{
// GetSelected()返回選擇item的UIblock的數(shù)組
for (int i = 0; i < m_pListCurves->GetSelected().size(); i++)
{
// 刪掉即可
m_pListCurves->Delete(m_pListCurves->GetSelected()[i]);
}
return 0;
}
實(shí)際上,你會(huì)發(fā)現(xiàn),如果你的子塊不需要特殊的處理的話,你甚至都不需要子塊對(duì)應(yīng)的hpp文件和cpp文件,因?yàn)闊o(wú)論是設(shè)置還是讀取,都是在集列表所在的主界面中實(shí)現(xiàn)的。
下面講一下,如何獲取集列表中的值,實(shí)際上在上面的回調(diào)函數(shù)代碼中已經(jīng)有了,不過(guò)這里還是專門寫一下,代碼供參考:
//author:autumoon
//郵箱:9506@163.com
//日期:2023-08-17
//---------Enter your code here-----------
// 用戶選擇的方向
Vector3d vec3d = m_pVectorZ->GetProperties()->GetVector("Vector");
AUTUMOONMathVector3d ivecUserZ(vec3d.X, vec3d.Y, vec3d.Z);
if (m_cfFeature.m_pvFaces.size() == 0)
{
uc1601("請(qǐng)選擇面!", 1);
return -1;
}
Face *pFirstFace = m_cfFeature.m_pvFaces[0];
AUTUMOONMathVector3d vecLaw = CAMFeaRecognition::GetFaceLawEx(pFirstFace);
if (vecLaw.IsSameDirection(ivecUserZ))
{
m_cfFeature.m_eCAMMachiningType = eMachiningTypeFront;
}
else if (vecLaw.IsParallel(ivecUserZ))
{
m_cfFeature.m_eCAMMachiningType = eMachiningTypeReverse;
}
else
{
m_cfFeature.m_eCAMMachiningType = eMachiningTypeFiveAxis;
}
// 添加平面銑顏色
m_cfFeature.m_nFeatureColor = pFirstFace->Color();
// 根據(jù)平面銑的當(dāng)前z方向,得到編程時(shí)的坐標(biāo)系
CAMFeaRecognition::GenerateWCSCoorByFeature(&m_cfFeature, ivecUserZ);
// 類型
int nSelIndex = m_pEnumMillType->AUTUMOONBLock_GetEnumValue;
m_cfFeature.m_eCAMMachiningMode = static_cast<ProcessingType>(eProcessingTypeFlatMillingOpen + nSelIndex);
// 從list列表獲取曲線信息
std::vector<UIBlock *> vAllBlocks = m_pListCurves->GetItems();
for (int i = 0; i < vAllBlocks.size(); i++)
{
// 強(qiáng)轉(zhuǎn)成NXOpen.BlockStyler.CompositeBlock,類似一個(gè)UI的集合,里面可以添加很多ui
NXOpen::BlockStyler::CompositeBlock *compositeBlock =
(NXOpen::BlockStyler::CompositeBlock *)vAllBlocks[i];
// 分別查找對(duì)應(yīng)的控件
NXOpen::BlockStyler::UIBlock *edge_select0 = compositeBlock->FindBlock("edge_select0");
NXOpen::BlockStyler::UIBlock *enumCamMethod = compositeBlock->FindBlock("enumCamMethod");
NXOpen::BlockStyler::UIBlock *enumMaterialSide = compositeBlock->FindBlock("enumMaterialSide");
NXOpen::BlockStyler::UIBlock *doubleProcessDis = compositeBlock->FindBlock("doubleProcessDis");
NXOpen::BlockStyler::UIBlock *doubleSelToolDia = compositeBlock->FindBlock("doubleSelToolDia");
NXOpen::BlockStyler::UIBlock *toggleRough = compositeBlock->FindBlock("toggleRough");
NXOpen::BlockStyler::UIBlock *toggleFinish = compositeBlock->FindBlock("toggleFinish");
vector<TaggedObject *> selectedCurves = edge_select0->AUTUMOONBLock_GetSelectedObjects;
if (m_cfFeature.m_vpCurveExs.size())
{
m_cfFeature.m_vpCurveExs.clear();
}
for (auto it = selectedCurves.begin(); it != selectedCurves.end(); ++it)
{
Curve *pCurveSel = static_cast<Curve *>(*it);
CurveEx *pCurveEx = new CurveEx(pCurveSel);
// 加工曲線位置
pCurveEx->m_nCurveCamMethod = enumCamMethod->AUTUMOONBLock_GetEnumValue;
// 材料側(cè)
pCurveEx->m_nMaterialSide = enumMaterialSide->AUTUMOONBLock_GetEnumValue + 1;
// 加工距離
pCurveEx->m_dProcessDistance = doubleProcessDis->AUTUMOONBLock_GetDoubleValue;
// 刀具直徑
pCurveEx->m_dSelToolDia = doubleSelToolDia->AUTUMOONBLock_GetDoubleValue;
// 粗加工
if (toggleRough->AUTUMOONBLock_GetLogicalValue)
{
pCurveEx->m_nMachiningMethod |= MACHINING_METHOD_ROUGH;
}
else
{
pCurveEx->m_nMachiningMethod &= ~MACHINING_METHOD_ROUGH;
}
// 半精加工和精加工
if (toggleFinish->AUTUMOONBLock_GetLogicalValue)
{
pCurveEx->m_nMachiningMethod |= MACHINING_METHOD_HALF_FINISH | MACHINING_METHOD_FINISH;
}
else
{
pCurveEx->m_nMachiningMethod &= ~(MACHINING_METHOD_HALF_FINISH | MACHINING_METHOD_FINISH);
}
// 加工面高度(從當(dāng)前主界面獲?。? pCurveEx->m_dDeepOffset = m_DoubleFaceHeight->AUTUMOONBLock_GetDoubleValue;
m_cfFeature.m_vpCurveExs.push_back(pCurveEx);
}
}
int nFindIndex = -1;
for (int i = 0; i < m_vFeatures.size(); ++i)
{
CAMFeature &cf = m_vFeatures[i];
if (cf.m_pvFaces.size())
{
Face *pFaceCur = cf.m_pvFaces[0];
if (pFaceCur == pFirstFace)
{
nFindIndex = i;
// 釋放原來(lái)的
if (cf.m_vpCurveExs.size())
{
CurveEx::ReleaseCurveEx(cf.m_vpCurveExs);
}
cf = m_cfFeature;
break;
}
}
}
// 添加
if (nFindIndex == -1)
{
m_vFeatures.push_back(m_cfFeature);
}
// 復(fù)位控件
resetAllCtrlBlock();
// 面選擇重新選擇為焦點(diǎn)
m_pSelFace->Focus();
獲取的關(guān)鍵是這一段:
此代碼也是我嘗試出來(lái)的結(jié)果,當(dāng)發(fā)現(xiàn)可以正常工作的時(shí)候,我還是很開(kāi)心的,畢竟這個(gè)代碼帶著一點(diǎn)點(diǎn)猜想的成分。文章來(lái)源:http://www.zghlxwxcb.cn/news/detail-777868.html
至此,集列表的創(chuàng)建以及回調(diào)函數(shù),以及獲取集列表上任意控件的值就已經(jīng)全部結(jié)束了。
歡迎交流與討論,歡迎留言或者私信我尋求幫助,謝謝。文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-777868.html
到了這里,關(guān)于【NX】NX二次開(kāi)發(fā)BlockUI集列表的詳細(xì)使用步驟的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!