IPXV_Document::CreateStdSel Method
From PDF XChange PDF SDK
m (Automatic page editing by robot) |
|||
(6 intermediate revisions by one other user not shown) | |||
Line 2: | Line 2: | ||
[[Category:Editor]] | [[Category:Editor]] | ||
{{#customTitle:IPXV_Document::CreateStdSel Method}} | {{#customTitle:IPXV_Document::CreateStdSel Method}} | ||
− | {{#parentPage:PXV:IPXV_Document|CreateStdSel | + | {{#parentPage:PXV:IPXV_Document#Methods|CreateStdSel|method}} |
− | + | ||
{{ToReview}} | {{ToReview}} | ||
− | + | Creates new selection by the specified selection ID. | |
== Syntax == | == Syntax == | ||
<pre class="brush:cpp;gutter:false">HRESULT CreateStdSel([in] ULONG nSelID, | <pre class="brush:cpp;gutter:false">HRESULT CreateStdSel([in] ULONG nSelID, | ||
− | [out, retval] IPXV_DocSelection** | + | [out, retval] IPXV_DocSelection** pNewSel);</pre> |
== Parameters == | == Parameters == | ||
;nSelID | ;nSelID | ||
− | :[in] Value of ULONG. | + | :[in] Value of ULONG containing the ID selection that needs to be created. |
− | ; | + | ;pNewSel |
− | :[out, retval] Pointer to [[PXV:IPXV_DocSelection|IPXV_DocSelection]]. | + | :[out, retval] Pointer to [[PXV:IPXV_DocSelection|IPXV_DocSelection]] containing the resulting selection. |
== Return Value == | == Return Value == | ||
Returns S_OK if operation was successful or error code in other cases. | Returns S_OK if operation was successful or error code in other cases. | ||
+ | |||
+ | == Sample == | ||
+ | <pre class="brush:c#">//C# | ||
+ | private void SetContentColor(PDFXEdit.IPXV_Document Doc, PDFXEdit.IPXV_Inst Inst) | ||
+ | { | ||
+ | if (Doc == null) | ||
+ | return; | ||
+ | //Creating contentItems.setProps operation | ||
+ | int nID = Inst.Str2ID("op.contentItems.setProps", false); | ||
+ | PDFXEdit.IOperation Op = Inst.CreateOp(nID); | ||
+ | var input = Op.Params.Root["Input"]; | ||
+ | input.Add().v = Doc.CoreDoc; | ||
+ | PDFXEdit.ICabNode options = Op.Params.Root["Options"]; | ||
+ | int nSelID = Inst.Str2ID("selection.contentItems", false); | ||
+ | uint nPage = 0; //Page number that will have it's content items modified | ||
+ | //First we need to create content items selection | ||
+ | PDFXEdit.IPXV_ContentItemsSelection itSel = (PDFXEdit.IPXV_ContentItemsSelection)Doc.CreateStdSel((uint)nSelID); | ||
+ | //Then we need to get root item entry for the desired page (we'll create it if needed) | ||
+ | PDFXEdit.IPXV_ContentItemEntry itEntry = itSel.GetSel(nPage, true); | ||
+ | //Inserting needed content items from the page | ||
+ | var content = Doc.CoreDoc.Pages[nPage].GetContent(PDFXEdit.PXC_ContentAccessMode.CAccessMode_WeakClone); | ||
+ | for (uint i = 0; i < content.Items.Count; i++) | ||
+ | { | ||
+ | //For example we will take all of the text items | ||
+ | if (content.Items[i].Type == PDFXEdit.PXC_CIType.CIT_Text) | ||
+ | itEntry.Insert(i); | ||
+ | } | ||
+ | //Adding selected page's root entry with added content items to the operation | ||
+ | options["Entries"].Add(PDFXEdit.CabDataTypeID.dt_IUnknown).v = itEntry; | ||
+ | //Setting the color (note that rgb notation is rgb(r,g,b) where r g b are float values from 0.0 to 1.0) | ||
+ | options["FColor"].v = "#AC3312"; | ||
+ | //Setting mask that will tell the operation that the FColor will be modified | ||
+ | options["Mask"].v = 2; | ||
+ | Op.Do(); | ||
+ | //Clearing the selection | ||
+ | itSel.Clear(); | ||
+ | } | ||
+ | </pre> | ||
== See Also == | == See Also == | ||
− | [[PXV:IPXV_Document|IPXV_Document]] | + | [[PXV:IPXV_Document|IPXV_Document]] |
Latest revision as of 00:50, 22 April 2016
Creates new selection by the specified selection ID.
Syntax
HRESULT CreateStdSel([in] ULONG nSelID, [out, retval] IPXV_DocSelection** pNewSel);
Parameters
- nSelID
- [in] Value of ULONG containing the ID selection that needs to be created.
- pNewSel
- [out, retval] Pointer to IPXV_DocSelection containing the resulting selection.
Return Value
Returns S_OK if operation was successful or error code in other cases.
Sample
//C# private void SetContentColor(PDFXEdit.IPXV_Document Doc, PDFXEdit.IPXV_Inst Inst) { if (Doc == null) return; //Creating contentItems.setProps operation int nID = Inst.Str2ID("op.contentItems.setProps", false); PDFXEdit.IOperation Op = Inst.CreateOp(nID); var input = Op.Params.Root["Input"]; input.Add().v = Doc.CoreDoc; PDFXEdit.ICabNode options = Op.Params.Root["Options"]; int nSelID = Inst.Str2ID("selection.contentItems", false); uint nPage = 0; //Page number that will have it's content items modified //First we need to create content items selection PDFXEdit.IPXV_ContentItemsSelection itSel = (PDFXEdit.IPXV_ContentItemsSelection)Doc.CreateStdSel((uint)nSelID); //Then we need to get root item entry for the desired page (we'll create it if needed) PDFXEdit.IPXV_ContentItemEntry itEntry = itSel.GetSel(nPage, true); //Inserting needed content items from the page var content = Doc.CoreDoc.Pages[nPage].GetContent(PDFXEdit.PXC_ContentAccessMode.CAccessMode_WeakClone); for (uint i = 0; i < content.Items.Count; i++) { //For example we will take all of the text items if (content.Items[i].Type == PDFXEdit.PXC_CIType.CIT_Text) itEntry.Insert(i); } //Adding selected page's root entry with added content items to the operation options["Entries"].Add(PDFXEdit.CabDataTypeID.dt_IUnknown).v = itEntry; //Setting the color (note that rgb notation is rgb(r,g,b) where r g b are float values from 0.0 to 1.0) options["FColor"].v = "#AC3312"; //Setting mask that will tell the operation that the FColor will be modified options["Mask"].v = 2; Op.Do(); //Clearing the selection itSel.Clear(); }