| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433 |
- /////////////////////////////////////////////////////////////////////////////
- // Name: dataview.h
- // Purpose: interface of wxDataView* classes
- // Author: wxWidgets team
- // Licence: wxWindows licence
- /////////////////////////////////////////////////////////////////////////////
- /**
- @class wxDataViewModel
- wxDataViewModel is the base class for all data model to be displayed by a
- wxDataViewCtrl.
- All other models derive from it and must implement its pure virtual functions
- in order to define a complete data model. In detail, you need to override
- wxDataViewModel::IsContainer, wxDataViewModel::GetParent, wxDataViewModel::GetChildren,
- wxDataViewModel::GetColumnCount, wxDataViewModel::GetColumnType and
- wxDataViewModel::GetValue in order to define the data model which acts as an
- interface between your actual data and the wxDataViewCtrl.
- Note that wxDataViewModel does not define the position or index of any item
- in the control because different controls might display the same data differently.
- wxDataViewModel does provide a wxDataViewModel::Compare method which the
- wxDataViewCtrl may use to sort the data either in conjunction with a column
- header or without (see wxDataViewModel::HasDefaultCompare).
- wxDataViewModel (as indeed the entire wxDataViewCtrl code) is using wxVariant
- to store data and its type in a generic way. wxVariant can be extended to contain
- almost any data without changes to the original class. To a certain extent,
- you can use (the somewhat more elegant) wxAny instead of wxVariant as there
- is code to convert between the two, but it is unclear what impact this will
- have on performance.
- Since you will usually allow the wxDataViewCtrl to change your data
- through its graphical interface, you will also have to override
- wxDataViewModel::SetValue which the wxDataViewCtrl will call when a change
- to some data has been committed.
- If the data represented by the model is changed by something else than its
- associated wxDataViewCtrl, the control has to be notified about the change.
- Depending on what happened you need to call one of the following methods:
- - wxDataViewModel::ValueChanged,
- - wxDataViewModel::ItemAdded,
- - wxDataViewModel::ItemDeleted,
- - wxDataViewModel::ItemChanged,
- - wxDataViewModel::Cleared.
- There are plural forms for notification of addition, change or removal of
- several item at once. See:
- - wxDataViewModel::ItemsAdded,
- - wxDataViewModel::ItemsDeleted,
- - wxDataViewModel::ItemsChanged.
- This class maintains a list of wxDataViewModelNotifier which link this class
- to the specific implementations on the supported platforms so that e.g. calling
- wxDataViewModel::ValueChanged on this model will just call
- wxDataViewModelNotifier::ValueChanged for each notifier that has been added.
- You can also add your own notifier in order to get informed about any changes
- to the data in the list model.
- Currently wxWidgets provides the following models apart from the base model:
- wxDataViewIndexListModel, wxDataViewVirtualListModel, wxDataViewTreeStore,
- wxDataViewListStore.
- Note that wxDataViewModel is reference counted, derives from wxRefCounter
- and cannot be deleted directly as it can be shared by several wxDataViewCtrls.
- This implies that you need to decrease the reference count after
- associating the model with a control like this:
- @code
- wxDataViewCtrl *musicCtrl = new wxDataViewCtrl( this, wxID_ANY );
- wxDataViewModel *musicModel = new MyMusicModel;
- m_musicCtrl->AssociateModel( musicModel );
- musicModel->DecRef(); // avoid memory leak !!
- // add columns now
- @endcode
- A potentially better way to avoid memory leaks is to use wxObjectDataPtr
-
- @code
- wxObjectDataPtr<MyMusicModel> musicModel;
-
- wxDataViewCtrl *musicCtrl = new wxDataViewCtrl( this, wxID_ANY );
- musicModel = new MyMusicModel;
- m_musicCtrl->AssociateModel( musicModel.get() );
- // add columns now
- @endcode
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewModel : public wxRefCounter
- {
- public:
- /**
- Constructor.
- */
- wxDataViewModel();
- /**
- Adds a wxDataViewModelNotifier to the model.
- */
- void AddNotifier(wxDataViewModelNotifier* notifier);
- /**
- Change the value of the given item and update the control to reflect
- it.
- This function simply calls SetValue() and, if it succeeded,
- ValueChanged().
- @since 2.9.1
- @param variant
- The new value.
- @param item
- The item (row) to update.
- @param col
- The column to update.
- @return
- @true if both SetValue() and ValueChanged() returned @true.
- */
- bool ChangeValue(const wxVariant& variant,
- const wxDataViewItem& item,
- unsigned int col);
- /**
- Called to inform the model that all data has been cleared.
- The control will reread the data from the model again.
- */
- virtual bool Cleared();
- /**
- The compare function to be used by control. The default compare function
- sorts by container and other items separately and in ascending order.
- Override this for a different sorting behaviour.
- @see HasDefaultCompare().
- */
- virtual int Compare(const wxDataViewItem& item1,
- const wxDataViewItem& item2,
- unsigned int column,
- bool ascending) const;
- /**
- Override this to indicate that the item has special font attributes.
- This only affects the wxDataViewTextRendererText renderer.
- The base class version always simply returns @false.
- @see wxDataViewItemAttr.
- @param item
- The item for which the attribute is requested.
- @param col
- The column of the item for which the attribute is requested.
- @param attr
- The attribute to be filled in if the function returns @true.
- @return
- @true if this item has an attribute or @false otherwise.
- */
- virtual bool GetAttr(const wxDataViewItem& item, unsigned int col,
- wxDataViewItemAttr& attr) const;
- /**
- Override this to indicate that the item should be disabled.
- Disabled items are displayed differently (e.g. grayed out) and cannot
- be interacted with.
- The base class version always returns @true, thus making all items
- enabled by default.
- @param item
- The item whose enabled status is requested.
- @param col
- The column of the item whose enabled status is requested.
- @return
- @true if this item should be enabled, @false otherwise.
- @note Currently disabling items is not supported by the wxOSX/Carbon
- implementation.
- @since 2.9.2
- */
- virtual bool IsEnabled(const wxDataViewItem &item,
- unsigned int col) const;
- /**
- Override this so the control can query the child items of an item.
- Returns the number of items.
- */
- virtual unsigned int GetChildren(const wxDataViewItem& item,
- wxDataViewItemArray& children) const = 0;
- /**
- Override this to indicate the number of columns in the model.
- */
- virtual unsigned int GetColumnCount() const = 0;
- /**
- Override this to indicate what type of data is stored in the
- column specified by @a col.
- This should return a string indicating the type of data as reported by wxVariant.
- */
- virtual wxString GetColumnType(unsigned int col) const = 0;
- /**
- Override this to indicate which wxDataViewItem representing the parent
- of @a item or an invalid wxDataViewItem if the root item is
- the parent item.
- */
- virtual wxDataViewItem GetParent(const wxDataViewItem& item) const = 0;
- /**
- Override this to indicate the value of @a item.
- A wxVariant is used to store the data.
- */
- virtual void GetValue(wxVariant& variant, const wxDataViewItem& item,
- unsigned int col) const = 0;
- /**
- Override this method to indicate if a container item merely acts as a
- headline (or for categorisation) or if it also acts a normal item with
- entries for further columns. By default returns @false.
- */
- virtual bool HasContainerColumns(const wxDataViewItem& item) const;
- /**
- Override this to indicate that the model provides a default compare
- function that the control should use if no wxDataViewColumn has been
- chosen for sorting. Usually, the user clicks on a column header for
- sorting, the data will be sorted alphanumerically.
- If any other order (e.g. by index or order of appearance) is required,
- then this should be used.
- See wxDataViewIndexListModel for a model which makes use of this.
- */
- virtual bool HasDefaultCompare() const;
- /**
- Return true if there is a value in the given column of this item.
- All normal items have values in all columns but the container items
- only show their label in the first column (@a col == 0) by default (but
- see HasContainerColumns()). So this function always returns true for
- the first column while for the other ones it returns true only if the
- item is not a container or HasContainerColumns() was overridden to
- return true for it.
- @since 2.9.1
- */
- bool HasValue(const wxDataViewItem& item, unsigned col) const;
- /**
- Override this to indicate of @a item is a container, i.e.\ if
- it can have child items.
- */
- virtual bool IsContainer(const wxDataViewItem& item) const = 0;
- /**
- Call this to inform the model that an item has been added to the data.
- */
- bool ItemAdded(const wxDataViewItem& parent,
- const wxDataViewItem& item);
- /**
- Call this to inform the model that an item has changed.
- This will eventually emit a @c wxEVT_DATAVIEW_ITEM_VALUE_CHANGED
- event (in which the column fields will not be set) to the user.
- */
- bool ItemChanged(const wxDataViewItem& item);
- /**
- Call this to inform the model that an item has been deleted from the data.
- */
- bool ItemDeleted(const wxDataViewItem& parent,
- const wxDataViewItem& item);
- /**
- Call this to inform the model that several items have been added to the data.
- */
- bool ItemsAdded(const wxDataViewItem& parent,
- const wxDataViewItemArray& items);
- /**
- Call this to inform the model that several items have changed.
- This will eventually emit @c wxEVT_DATAVIEW_ITEM_VALUE_CHANGED
- events (in which the column fields will not be set) to the user.
- */
- bool ItemsChanged(const wxDataViewItemArray& items);
- /**
- Call this to inform the model that several items have been deleted.
- */
- bool ItemsDeleted(const wxDataViewItem& parent,
- const wxDataViewItemArray& items);
- /**
- Remove the @a notifier from the list of notifiers.
- */
- void RemoveNotifier(wxDataViewModelNotifier* notifier);
- /**
- Call this to initiate a resort after the sort function has been changed.
- */
- virtual void Resort();
- /**
- This gets called in order to set a value in the data model.
- The most common scenario is that the wxDataViewCtrl calls this method
- after the user changed some data in the view.
- This is the function you need to override in your derived class but if
- you want to call it, ChangeValue() is usually more convenient as
- otherwise you need to manually call ValueChanged() to update the
- control itself.
- */
- virtual bool SetValue(const wxVariant& variant,
- const wxDataViewItem& item,
- unsigned int col) = 0;
- /**
- Call this to inform this model that a value in the model has been changed.
- This is also called from wxDataViewCtrl's internal editing code, e.g. when
- editing a text field in the control.
- This will eventually emit a @c wxEVT_DATAVIEW_ITEM_VALUE_CHANGED
- event to the user.
- */
- virtual bool ValueChanged(const wxDataViewItem& item,
- unsigned int col);
-
- virtual bool IsListModel() const;
- virtual bool IsVirtualListModel() const;
- protected:
- /**
- Destructor. This should not be called directly. Use DecRef() instead.
- */
- virtual ~wxDataViewModel();
- };
- /**
- @class wxDataViewListModel
- Base class with abstract API for wxDataViewIndexListModel and
- wxDataViewVirtualListModel.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewListModel : public wxDataViewModel
- {
- public:
- /**
- Destructor.
- */
- virtual ~wxDataViewListModel();
- /**
- Compare method that sorts the items by their index.
- */
- int Compare(const wxDataViewItem& item1,
- const wxDataViewItem& item2,
- unsigned int column, bool ascending) const;
- /**
- Override this to indicate that the row has special font attributes.
- This only affects the wxDataViewTextRendererText() renderer.
- The base class version always simply returns @false.
- @see wxDataViewItemAttr.
- @param row
- The row for which the attribute is requested.
- @param col
- The column for which the attribute is requested.
- @param attr
- The attribute to be filled in if the function returns @true.
- @return
- @true if this item has an attribute or @false otherwise.
- */
- virtual bool GetAttrByRow(unsigned int row, unsigned int col,
- wxDataViewItemAttr& attr) const;
- /**
- Override this if you want to disable specific items.
- The base class version always returns @true, thus making all items
- enabled by default.
- @param row
- The row of the item whose enabled status is requested.
- @param col
- The column of the item whose enabled status is requested.
- @return
- @true if the item at this row and column should be enabled,
- @false otherwise.
- @note See wxDataViewModel::IsEnabled() for the current status of
- support for disabling the items under different platforms.
- @since 2.9.2
- */
- virtual bool IsEnabledByRow(unsigned int row,
- unsigned int col) const;
- /**
- Returns the number of items (or rows) in the list.
- */
- unsigned int GetCount() const = 0;
- /**
- Returns the position of given @e item.
- */
- unsigned int GetRow(const wxDataViewItem& item) const = 0;
- /**
- Override this to allow getting values from the model.
- */
- virtual void GetValueByRow(wxVariant& variant, unsigned int row,
- unsigned int col) const = 0;
- /**
- Called in order to set a value in the model.
- */
- virtual bool SetValueByRow(const wxVariant& variant, unsigned int row,
- unsigned int col) = 0;
- };
- /**
- @class wxDataViewIndexListModel
- wxDataViewIndexListModel is a specialized data model which lets you address
- an item by its position (row) rather than its wxDataViewItem (which you can
- obtain from this class).
- This model also provides its own wxDataViewIndexListModel::Compare
- method which sorts the model's data by the index.
- This model is not a virtual model since the control stores each wxDataViewItem.
- Use wxDataViewVirtualListModel if you need to display millions of items or
- have other reason to use a virtual control.
- @see wxDataViewListModel for the API.
-
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewIndexListModel : public wxDataViewListModel
- {
- public:
- /**
- Constructor.
- */
- wxDataViewIndexListModel(unsigned int initial_size = 0);
- /**
- Returns the wxDataViewItem at the given @e row.
- */
- wxDataViewItem GetItem(unsigned int row) const;
- /**
- Call this after if the data has to be read again from the model.
- This is useful after major changes when calling the methods below
- (possibly thousands of times) doesn't make sense.
- */
- void Reset(unsigned int new_size);
- /**
- Call this after a row has been appended to the model.
- */
- void RowAppended();
- /**
- Call this after a row has been changed.
- */
- void RowChanged(unsigned int row);
- /**
- Call this after a row has been deleted.
- */
- void RowDeleted(unsigned int row);
- /**
- Call this after a row has been inserted at the given position.
- */
- void RowInserted(unsigned int before);
- /**
- Call this after a row has been prepended to the model.
- */
- void RowPrepended();
- /**
- Call this after a value has been changed.
- */
- void RowValueChanged(unsigned int row, unsigned int col);
- /**
- Call this after rows have been deleted.
- The array will internally get copied and sorted in descending order so
- that the rows with the highest position will be deleted first.
- */
- void RowsDeleted(const wxArrayInt& rows);
- };
- /**
- @class wxDataViewVirtualListModel
- wxDataViewVirtualListModel is a specialized data model which lets you address
- an item by its position (row) rather than its wxDataViewItem and as such offers
- the exact same interface as wxDataViewIndexListModel.
- The important difference is that under platforms other than OS X, using this
- model will result in a truly virtual control able to handle millions of items
- as the control doesn't store any item (a feature not supported by OS X).
- @see wxDataViewListModel for the API.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewVirtualListModel : public wxDataViewListModel
- {
- public:
- /**
- Constructor.
- */
- wxDataViewVirtualListModel(unsigned int initial_size = 0);
- /**
- Returns the wxDataViewItem at the given @e row.
- */
- wxDataViewItem GetItem(unsigned int row) const;
- /**
- Call this after if the data has to be read again from the model.
- This is useful after major changes when calling the methods below
- (possibly thousands of times) doesn't make sense.
- */
- void Reset(unsigned int new_size);
- /**
- Call this after a row has been appended to the model.
- */
- void RowAppended();
- /**
- Call this after a row has been changed.
- */
- void RowChanged(unsigned int row);
- /**
- Call this after a row has been deleted.
- */
- void RowDeleted(unsigned int row);
- /**
- Call this after a row has been inserted at the given position.
- */
- void RowInserted(unsigned int before);
- /**
- Call this after a row has been prepended to the model.
- */
- void RowPrepended();
- /**
- Call this after a value has been changed.
- */
- void RowValueChanged(unsigned int row, unsigned int col);
- /**
- Call this after rows have been deleted.
- The array will internally get copied and sorted in descending order so
- that the rows with the highest position will be deleted first.
- */
- void RowsDeleted(const wxArrayInt& rows);
- };
- /**
- @class wxDataViewItemAttr
- This class is used to indicate to a wxDataViewCtrl that a certain item
- (see wxDataViewItem) has extra font attributes for its renderer.
- For this, it is required to override wxDataViewModel::GetAttr.
- Attributes are currently only supported by wxDataViewTextRendererText.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewItemAttr
- {
- public:
- /**
- Constructor.
- */
- wxDataViewItemAttr();
- /**
- Call this to indicate that the item shall be displayed in bold text.
- */
- void SetBold(bool set);
- /**
- Call this to indicate that the item shall be displayed with that colour.
- */
- void SetColour(const wxColour& colour);
- /**
- Call this to set the background colour to use.
- Currently this attribute is only supported in the generic version of
- wxDataViewCtrl and ignored by the native GTK+ and OS X implementations.
- @since 2.9.4
- */
- void SetBackgroundColour(const wxColour& colour);
- /**
- Call this to indicate that the item shall be displayed in italic text.
- */
- void SetItalic(bool set);
- /**
- Returns true if the colour property has been set.
- */
- bool HasColour() const;
- /**
- Returns this attribute's colour.
- */
- const wxColour& GetColour() const;
- /**
- Returns true if any property affecting the font has been set.
- */
- bool HasFont() const;
- /**
- Returns value of the bold property.
- */
- bool GetBold() const;
- /**
- Returns value of the italics property.
- */
- bool GetItalic() const;
- /**
- Returns true if the background colour property has been set.
- */
- bool HasBackgroundColour() const;
- /**
- Returns the colour to be used for the background.
- */
- const wxColour& GetBackgroundColour() const;
- /**
- Returns true if none of the properties have been set.
- */
- bool IsDefault() const;
- /**
- Return the font based on the given one with this attribute applied to it.
- */
- wxFont GetEffectiveFont(const wxFont& font) const;
- };
- /**
- @class wxDataViewItem
- wxDataViewItem is a small opaque class that represents an item in a wxDataViewCtrl
- in a persistent way, i.e. independent of the position of the item in the control
- or changes to its contents.
- It must hold a unique ID of type @e void* in its only field and can be converted
- to and from it.
- If the ID is @NULL the wxDataViewItem is invalid and wxDataViewItem::IsOk will
- return @false which used in many places in the API of wxDataViewCtrl to
- indicate that e.g. no item was found. An ID of @NULL is also used to indicate
- the invisible root. Examples for this are wxDataViewModel::GetParent and
- wxDataViewModel::GetChildren.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewItem
- {
- public:
- //@{
- /**
- Constructor.
- */
- wxDataViewItem();
- wxDataViewItem(const wxDataViewItem& item);
- explicit wxDataViewItem(void* id);
- //@}
- /**
- Returns the ID.
- */
- void* GetID() const;
- /**
- Returns @true if the ID is not @NULL.
- */
- bool IsOk() const;
- };
- // ----------------------------------------------------------------------------
- // wxDataViewCtrl flags
- // ----------------------------------------------------------------------------
- // size of a wxDataViewRenderer without contents:
- #define wxDVC_DEFAULT_RENDERER_SIZE 20
- // the default width of new (text) columns:
- #define wxDVC_DEFAULT_WIDTH 80
- // the default width of new toggle columns:
- #define wxDVC_TOGGLE_DEFAULT_WIDTH 30
- // the default minimal width of the columns:
- #define wxDVC_DEFAULT_MINWIDTH 30
- // The default alignment of wxDataViewRenderers is to take
- // the alignment from the column it owns.
- #define wxDVR_DEFAULT_ALIGNMENT -1
- #define wxDV_SINGLE 0x0000 // for convenience
- #define wxDV_MULTIPLE 0x0001 // can select multiple items
- #define wxDV_NO_HEADER 0x0002 // column titles not visible
- #define wxDV_HORIZ_RULES 0x0004 // light horizontal rules between rows
- #define wxDV_VERT_RULES 0x0008 // light vertical rules between columns
- #define wxDV_ROW_LINES 0x0010 // alternating colour in rows
- #define wxDV_VARIABLE_LINE_HEIGHT 0x0020 // variable line height
- // events
- wxEventType wxEVT_DATAVIEW_SELECTION_CHANGED;
- wxEventType wxEVT_DATAVIEW_ITEM_ACTIVATED;
- wxEventType wxEVT_DATAVIEW_ITEM_COLLAPSING;
- wxEventType wxEVT_DATAVIEW_ITEM_COLLAPSED;
- wxEventType wxEVT_DATAVIEW_ITEM_EXPANDING;
- wxEventType wxEVT_DATAVIEW_ITEM_EXPANDED;
- wxEventType wxEVT_DATAVIEW_ITEM_START_EDITING;
- wxEventType wxEVT_DATAVIEW_ITEM_EDITING_STARTED;
- wxEventType wxEVT_DATAVIEW_ITEM_EDITING_DONE;
- wxEventType wxEVT_DATAVIEW_ITEM_VALUE_CHANGED;
- wxEventType wxEVT_DATAVIEW_ITEM_CONTEXT_MENU;
- wxEventType wxEVT_DATAVIEW_COLUMN_HEADER_CLICK;
- wxEventType wxEVT_DATAVIEW_COLUMN_HEADER_RIGHT_CLICK;
- wxEventType wxEVT_DATAVIEW_COLUMN_SORTED;
- wxEventType wxEVT_DATAVIEW_COLUMN_REORDERED;
- wxEventType wxEVT_DATAVIEW_CACHE_HINT;
- wxEventType wxEVT_DATAVIEW_ITEM_BEGIN_DRAG;
- wxEventType wxEVT_DATAVIEW_ITEM_DROP_POSSIBLE;
- wxEventType wxEVT_DATAVIEW_ITEM_DROP;
- /**
- @class wxDataViewCtrl
- wxDataViewCtrl is a control to display data either in a tree like fashion or
- in a tabular form or both.
- If you only need to display a simple tree structure with an API more like the
- older wxTreeCtrl class, then the specialized wxDataViewTreeCtrl can be used.
- Likewise, if you only want to display simple table structure you can use
- the specialized wxDataViewListCtrl class. Both wxDataViewTreeCtrl and
- wxDataViewListCtrl can be used without defining your own wxDataViewModel.
- A wxDataViewItem is used to represent a (visible) item in the control.
- Unlike wxListCtrl, wxDataViewCtrl doesn't get its data from the user through
- virtual functions or by setting it directly. Instead you need to write your own
- wxDataViewModel and associate it with this control.
- Then you need to add a number of wxDataViewColumn to this control to define
- what each column shall display. Each wxDataViewColumn in turn owns 1 instance
- of a wxDataViewRenderer to render its cells.
- A number of standard renderers for rendering text, dates, images, toggle,
- a progress bar etc. are provided. Additionally, the user can write custom
- renderers deriving from wxDataViewCustomRenderer for displaying anything.
- All data transfer from the control to the model and the user code is done
- through wxVariant which can be extended to support more data formats as necessary.
- Accordingly, all type information uses the strings returned from wxVariant::GetType.
- @beginStyleTable
- @style{wxDV_SINGLE}
- Single selection mode. This is the default.
- @style{wxDV_MULTIPLE}
- Multiple selection mode.
- @style{wxDV_ROW_LINES}
- Use alternating colours for rows if supported by platform and theme.
- Currently only supported by the native GTK and OS X implementations
- but not by the generic one.
- @style{wxDV_HORIZ_RULES}
- Display the separator lines between rows.
- @style{wxDV_VERT_RULES}
- Display the separator lines between columns.
- @style{wxDV_VARIABLE_LINE_HEIGHT}
- Allow variable line heights.
- This can be inefficient when displaying large number of items.
- @style{wxDV_NO_HEADER}
- Do not show column headers (which are shown by default).
- @endStyleTable
- @beginEventEmissionTable{wxDataViewEvent}
- @event{EVT_DATAVIEW_SELECTION_CHANGED(id, func)}
- Process a @c wxEVT_DATAVIEW_SELECTION_CHANGED event.
- @event{EVT_DATAVIEW_ITEM_ACTIVATED(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_ACTIVATED event. This event
- is triggered by double clicking an item or pressing some special key
- (usually "Enter") when it is focused.
- @event{EVT_DATAVIEW_ITEM_START_EDITING(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_START_EDITING event. This
- event can be vetoed in order to prevent editing on an item by item
- basis.
- @event{EVT_DATAVIEW_ITEM_EDITING_STARTED(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_EDITING_STARTED event.
- @event{EVT_DATAVIEW_ITEM_EDITING_DONE(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_EDITING_DONE event.
- @event{EVT_DATAVIEW_ITEM_COLLAPSING(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_COLLAPSING event.
- @event{EVT_DATAVIEW_ITEM_COLLAPSED(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_COLLAPSED event.
- @event{EVT_DATAVIEW_ITEM_EXPANDING(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_EXPANDING event.
- @event{EVT_DATAVIEW_ITEM_EXPANDED(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_EXPANDED event.
- @event{EVT_DATAVIEW_ITEM_VALUE_CHANGED(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_VALUE_CHANGED event.
- @event{EVT_DATAVIEW_ITEM_CONTEXT_MENU(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_CONTEXT_MENU event
- generated when the user right clicks inside the control. Notice that
- this menu is generated even if the click didn't occur on any valid
- item, in this case wxDataViewEvent::GetItem() simply returns an
- invalid item.
- @event{EVT_DATAVIEW_COLUMN_HEADER_CLICK(id, func)}
- Process a @c wxEVT_DATAVIEW_COLUMN_HEADER_CLICK event.
- @event{EVT_DATAVIEW_COLUMN_HEADER_RIGHT_CLICK(id, func)}
- Process a @c wxEVT_DATAVIEW_COLUMN_HEADER_RIGHT_CLICK event.
- Notice that currently this event is not generated in the native OS X
- versions of the control.
- @event{EVT_DATAVIEW_COLUMN_SORTED(id, func)}
- Process a @c wxEVT_DATAVIEW_COLUMN_SORTED event.
- @event{EVT_DATAVIEW_COLUMN_REORDERED(id, func)}
- Process a @c wxEVT_DATAVIEW_COLUMN_REORDERED event.
- @event{EVT_DATAVIEW_ITEM_BEGIN_DRAG(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_BEGIN_DRAG event.
- @event{EVT_DATAVIEW_ITEM_DROP_POSSIBLE(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_DROP_POSSIBLE event.
- @event{EVT_DATAVIEW_ITEM_DROP(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_DROP event.
- @endEventTable
- Notice that this control doesn't allow to process generic mouse events such
- as @c wxEVT_LEFT_DOWN in all ports (notably it doesn't work in wxGTK). If
- you need to handle any mouse events not covered by the ones above, consider
- using a custom renderer for the cells that must handle them.
- @library{wxadv}
- @category{ctrl,dvc}
- @appearance{dataviewctrl}
- */
- class wxDataViewCtrl : public wxControl
- {
- public:
- /**
- Default Constructor.
- */
- wxDataViewCtrl();
- /**
- Constructor. Calls Create().
- */
- wxDataViewCtrl(wxWindow* parent, wxWindowID id,
- const wxPoint& pos = wxDefaultPosition,
- const wxSize& size = wxDefaultSize,
- long style = 0,
- const wxValidator& validator = wxDefaultValidator,
- const wxString& name = wxDataViewCtrlNameStr);
- /**
- Destructor.
- */
- virtual ~wxDataViewCtrl();
- /**
- Create the control. Useful for two step creation.
- */
- bool Create(wxWindow* parent, wxWindowID id,
- const wxPoint& pos = wxDefaultPosition,
- const wxSize& size = wxDefaultSize,
- long style = 0,
- const wxValidator& validator = wxDefaultValidator,
- const wxString& name = wxDataViewCtrlNameStr);
- /**
- Appends a wxDataViewColumn to the control. Returns @true on success.
- Note that there is a number of short cut methods which implicitly create
- a wxDataViewColumn and a wxDataViewRenderer for it (see below).
- */
- virtual bool AppendColumn(wxDataViewColumn* col);
- /**
- Prepends a wxDataViewColumn to the control. Returns @true on success.
- Note that there is a number of short cut methods which implicitly create
- a wxDataViewColumn and a wxDataViewRenderer for it.
- */
- virtual bool PrependColumn(wxDataViewColumn* col);
- /**
- Inserts a wxDataViewColumn to the control. Returns @true on success.
- */
- virtual bool InsertColumn(unsigned int pos, wxDataViewColumn* col);
- //@{
- /**
- Appends a column for rendering a bitmap. Returns the wxDataViewColumn
- created in the function or @NULL on failure.
- */
- wxDataViewColumn* AppendBitmapColumn(const wxString& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- wxDataViewColumn* AppendBitmapColumn(const wxBitmap& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- //@}
- //@{
- /**
- Prepends a column for rendering a bitmap. Returns the wxDataViewColumn
- created in the function or @NULL on failure.
- */
- wxDataViewColumn* PrependBitmapColumn(const wxString& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- wxDataViewColumn* PrependBitmapColumn(const wxBitmap& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- //@}
- //@{
- /**
- Appends a column for rendering a date. Returns the wxDataViewColumn
- created in the function or @NULL on failure.
- @note The @a align parameter is applied to both the column header and
- the column renderer.
- */
- wxDataViewColumn* AppendDateColumn(const wxString& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_ACTIVATABLE,
- int width = -1,
- wxAlignment align = wxALIGN_NOT,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- wxDataViewColumn* AppendDateColumn(const wxBitmap& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_ACTIVATABLE,
- int width = -1,
- wxAlignment align = wxALIGN_NOT,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- //@}
- //@{
- /**
- Prepends a column for rendering a date. Returns the wxDataViewColumn
- created in the function or @NULL on failure.
- @note The @a align parameter is applied to both the column header and
- the column renderer.
- */
- wxDataViewColumn* PrependDateColumn(const wxString& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_ACTIVATABLE,
- int width = -1,
- wxAlignment align = wxALIGN_NOT,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- wxDataViewColumn* PrependDateColumn(const wxBitmap& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_ACTIVATABLE,
- int width = -1,
- wxAlignment align = wxALIGN_NOT,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- //@}
- //@{
- /**
- Appends a column for rendering text with an icon. Returns the wxDataViewColumn
- created in the function or @NULL on failure.
- This method uses the wxDataViewIconTextRenderer class.
- @note The @a align parameter is applied to both the column header and
- the column renderer.
- */
- wxDataViewColumn* AppendIconTextColumn(const wxString& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1,
- wxAlignment align = wxALIGN_NOT,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- wxDataViewColumn* AppendIconTextColumn(const wxBitmap& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1,
- wxAlignment align = wxALIGN_NOT,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- //@}
- //@{
- /**
- Prepends a column for rendering text with an icon. Returns the wxDataViewColumn
- created in the function or @NULL on failure.
- This method uses the wxDataViewIconTextRenderer class.
- @note The @a align parameter is applied to both the column header and
- the column renderer.
- */
- wxDataViewColumn* PrependIconTextColumn(const wxString& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1,
- wxAlignment align = wxALIGN_NOT,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- wxDataViewColumn* PrependIconTextColumn(const wxBitmap& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1,
- wxAlignment align = wxALIGN_NOT,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- //@}
- //@{
- /**
- Appends a column for rendering a progress indicator. Returns the
- wxDataViewColumn created in the function or @NULL on failure.
- @note The @a align parameter is applied to both the column header and
- the column renderer.
- */
- wxDataViewColumn* AppendProgressColumn(const wxString& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = 80,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- wxDataViewColumn* AppendProgressColumn(const wxBitmap& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = 80,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- //@}
- //@{
- /**
- Prepends a column for rendering a progress indicator. Returns the
- wxDataViewColumn created in the function or @NULL on failure.
- @note The @a align parameter is applied to both the column header and
- the column renderer.
- */
- wxDataViewColumn* PrependProgressColumn(const wxString& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = 80,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- wxDataViewColumn* PrependProgressColumn(const wxBitmap& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = 80,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- //@}
- //@{
- /**
- Appends a column for rendering text. Returns the wxDataViewColumn
- created in the function or @NULL on failure.
- @note The @a align parameter is applied to both the column header and
- the column renderer.
- */
- wxDataViewColumn* AppendTextColumn(const wxString& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1,
- wxAlignment align = wxALIGN_NOT,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- wxDataViewColumn* AppendTextColumn(const wxBitmap& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1,
- wxAlignment align = wxALIGN_NOT,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- //@}
- //@{
- /**
- Prepends a column for rendering text. Returns the wxDataViewColumn
- created in the function or @NULL on failure.
- @note The @a align parameter is applied to both the column header and
- the column renderer.
- */
- wxDataViewColumn* PrependTextColumn(const wxString& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1,
- wxAlignment align = wxALIGN_NOT,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- wxDataViewColumn* PrependTextColumn(const wxBitmap& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1,
- wxAlignment align = wxALIGN_NOT,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- //@}
- //@{
- /**
- Appends a column for rendering a toggle. Returns the wxDataViewColumn
- created in the function or @NULL on failure.
- @note The @a align parameter is applied to both the column header and
- the column renderer.
- */
- wxDataViewColumn* AppendToggleColumn(const wxString& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = 30,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- wxDataViewColumn* AppendToggleColumn(const wxBitmap& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = 30,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- //@}
- //@{
- /**
- Prepends a column for rendering a toggle. Returns the wxDataViewColumn
- created in the function or @NULL on failure.
- @note The @a align parameter is applied to both the column header and
- the column renderer.
- */
- wxDataViewColumn* PrependToggleColumn(const wxString& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = 30,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- wxDataViewColumn* PrependToggleColumn(const wxBitmap& label,
- unsigned int model_column,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = 30,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- //@}
- /**
- Associates a wxDataViewModel with the control.
- This increases the reference count of the model by 1.
- */
- virtual bool AssociateModel(wxDataViewModel* model);
- /**
- Removes all columns.
- */
- virtual bool ClearColumns();
- /**
- Collapses the item.
- */
- virtual void Collapse(const wxDataViewItem& item);
- /**
- Deletes given column.
- */
- virtual bool DeleteColumn(wxDataViewColumn* column);
- /**
- Programmatically starts editing given cell of @a item.
- Doesn't do anything if the item or this column is not editable.
- @note Currently not implemented in wxOSX/Carbon.
- @since 2.9.4
- */
- virtual void EditItem(const wxDataViewItem& item, const wxDataViewColumn *column);
- /**
- Enable drag operations using the given @a format.
- */
- virtual bool EnableDragSource( const wxDataFormat &format );
- /**
- Enable drop operations using the given @a format.
- */
- virtual bool EnableDropTarget( const wxDataFormat &format );
- /**
- Call this to ensure that the given item is visible.
- */
- virtual void EnsureVisible(const wxDataViewItem& item,
- const wxDataViewColumn* column = NULL);
- /**
- Expands the item.
- */
- virtual void Expand(const wxDataViewItem& item);
- /**
- Expands all ancestors of the @a item. This method also
- ensures that the item itself as well as all ancestor
- items have been read from the model by the control.
- */
- virtual void ExpandAncestors( const wxDataViewItem & item );
- /**
- Returns pointer to the column. @a pos refers to the position in the
- control which may change after reordering columns by the user.
- */
- virtual wxDataViewColumn* GetColumn(unsigned int pos) const;
- /**
- Returns the number of columns.
- */
- virtual unsigned int GetColumnCount() const;
- /**
- Returns the position of the column or -1 if not found in the control.
- */
- virtual int GetColumnPosition(const wxDataViewColumn* column) const;
- /**
- Returns column containing the expanders.
- */
- wxDataViewColumn* GetExpanderColumn() const;
- /**
- Returns the currently focused item.
- This is the item that the keyboard commands apply to. It may be invalid
- if there is no focus currently.
- This method is mostly useful for the controls with @c wxDV_MULTIPLE
- style as in the case of single selection it returns the same thing as
- GetSelection().
- Notice that under all platforms except Mac OS X the currently focused
- item may be selected or not but under OS X the current item is always
- selected.
- @see SetCurrentItem(), GetCurrentColumn()
- @since 2.9.2
- */
- wxDataViewItem GetCurrentItem() const;
- /**
- Returns the column that currently has focus.
- If the focus is set to individual cell within the currently focused
- item (as opposed to being on the item as a whole), then this is the
- column that the focus is on.
- Returns NULL if no column currently has focus.
- @see GetCurrentItem()
- @since 2.9.4
- */
- wxDataViewColumn *GetCurrentColumn() const;
- /**
- Returns indentation.
- */
- int GetIndent() const;
- /**
- Returns item rectangle.
- This method is currently not implemented at all in wxGTK and only
- implemented for non-@NULL @a col argument in wxOSX. It is fully
- implemented in the generic version of the control.
- @param item
- A valid item.
- @param col
- If non-@NULL, the rectangle returned corresponds to the
- intersection of the item with the specified column. If @NULL, the
- rectangle spans all the columns.
- */
- virtual wxRect GetItemRect(const wxDataViewItem& item,
- const wxDataViewColumn* col = NULL) const;
- /**
- Returns pointer to the data model associated with the control (if any).
- */
- wxDataViewModel* GetModel();
- /**
- Returns the number of currently selected items.
- This method may be called for both the controls with single and
- multiple selections and returns the number of selected item, possibly
- 0, in any case.
- @since 2.9.3
- */
- virtual int GetSelectedItemsCount() const;
- /**
- Returns first selected item or an invalid item if none is selected.
- This method may be called for both the controls with single and
- multiple selections but returns an invalid item if more than one item
- is selected in the latter case, use HasSelection() to determine if
- there are any selected items when using multiple selection.
- */
- virtual wxDataViewItem GetSelection() const;
- /**
- Fills @a sel with currently selected items and returns their number.
- This method may be called for both the controls with single and
- multiple selections. In the single selection case it returns the array
- with at most one element in it.
- @see GetSelectedItemsCount()
- */
- virtual int GetSelections(wxDataViewItemArray& sel) const;
- /**
- Returns the wxDataViewColumn currently responsible for sorting
- or @NULL if none has been selected.
- */
- virtual wxDataViewColumn* GetSortingColumn() const;
- /**
- Returns true if any items are currently selected.
- This method may be called for both the controls with single and
- multiple selections.
- Calling this method is equivalent to calling GetSelectedItemsCount()
- and comparing its result with 0 but is more clear and might also be
- implemented more efficiently in the future.
- @since 2.9.3
- */
- bool HasSelection() const;
- /**
- Hittest.
- */
- virtual void HitTest(const wxPoint& point, wxDataViewItem& item,
- wxDataViewColumn*& col) const;
- /**
- Return @true if the item is expanded.
- */
- virtual bool IsExpanded(const wxDataViewItem& item) const;
- /**
- Return @true if the item is selected.
- */
- virtual bool IsSelected(const wxDataViewItem& item) const;
- /**
- Select the given item.
- In single selection mode this changes the (unique) currently selected
- item. In multi selection mode, the @a item is selected and the
- previously selected items remain selected.
- */
- virtual void Select(const wxDataViewItem& item);
- /**
- Select all items.
- */
- virtual void SelectAll();
- /**
- Set which column shall contain the tree-like expanders.
- */
- void SetExpanderColumn(wxDataViewColumn* col);
- /**
- Changes the currently focused item.
- The @a item parameter must be valid, there is no way to remove the
- current item from the control.
- In single selection mode, calling this method is the same as calling
- Select() and is thus not very useful. In multiple selection mode this
- method only moves the current item however without changing the
- selection except under OS X where the current item is always selected,
- so calling SetCurrentItem() selects @a item if it hadn't been selected
- before.
- @see GetCurrentItem()
- @since 2.9.2
- */
- void SetCurrentItem(const wxDataViewItem& item);
- /**
- Sets the indentation.
- */
- void SetIndent(int indent);
- /**
- Sets the selection to the array of wxDataViewItems.
- */
- virtual void SetSelections(const wxDataViewItemArray& sel);
- /**
- Unselect the given item.
- */
- virtual void Unselect(const wxDataViewItem& item);
- /**
- Unselect all item.
- This method only has effect if multiple selections are allowed.
- */
- virtual void UnselectAll();
- /**
- Sets the row height.
- This function can only be used when all rows have the same height, i.e.
- when wxDV_VARIABLE_LINE_HEIGHT flag is not used.
- Currently this is implemented in the generic and native GTK versions
- only and nothing is done (and @false returned) when using OS X port.
- Also notice that this method can only be used to increase the row
- height compared with the default one (as determined by the return value
- of wxDataViewRenderer::GetSize()), if it is set to a too small value
- then the minimum required by the renderers will be used.
- @return @true if the line height was changed or @false otherwise.
- @since 2.9.2
- */
- virtual bool SetRowHeight(int rowHeight);
- };
- /**
- @class wxDataViewModelNotifier
- A wxDataViewModelNotifier instance is owned by a wxDataViewModel and mirrors
- its notification interface.
- See the documentation of that class for further information.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewModelNotifier
- {
- public:
- /**
- Constructor.
- */
- wxDataViewModelNotifier();
- /**
- Destructor.
- */
- virtual ~wxDataViewModelNotifier();
- /**
- Called by owning model.
- */
- virtual bool Cleared() = 0;
- /**
- Get owning wxDataViewModel.
- */
- wxDataViewModel* GetOwner() const;
- /**
- Called by owning model.
- @return Always return @true from this function in derived classes.
- */
- virtual bool ItemAdded(const wxDataViewItem& parent,
- const wxDataViewItem& item) = 0;
- /**
- Called by owning model.
- @return Always return @true from this function in derived classes.
- */
- virtual bool ItemChanged(const wxDataViewItem& item) = 0;
- /**
- Called by owning model.
- @return Always return @true from this function in derived classes.
- */
- virtual bool ItemDeleted(const wxDataViewItem& parent,
- const wxDataViewItem& item) = 0;
- /**
- Called by owning model.
- @return Always return @true from this function in derived classes.
- */
- virtual bool ItemsAdded(const wxDataViewItem& parent,
- const wxDataViewItemArray& items);
- /**
- Called by owning model.
- @return Always return @true from this function in derived classes.
- */
- virtual bool ItemsChanged(const wxDataViewItemArray& items);
- /**
- Called by owning model.
- @return Always return @true from this function in derived classes.
- */
- virtual bool ItemsDeleted(const wxDataViewItem& parent,
- const wxDataViewItemArray& items);
- /**
- Called by owning model.
- */
- virtual void Resort() = 0;
- /**
- Set owner of this notifier. Used internally.
- */
- void SetOwner(wxDataViewModel* owner);
- /**
- Called by owning model.
- @return Always return @true from this function in derived classes.
- */
- virtual bool ValueChanged(const wxDataViewItem& item, unsigned int col) = 0;
- };
- /**
- The mode of a data-view cell; see wxDataViewRenderer for more info.
- */
- enum wxDataViewCellMode
- {
- /**
- The cell only displays information and cannot be manipulated or
- otherwise interacted with in any way.
- Note that this doesn't mean that the row being drawn can't be selected,
- just that a particular element of it cannot be individually modified.
- */
- wxDATAVIEW_CELL_INERT,
- /**
- Indicates that the cell can be @em activated by clicking it or using
- keyboard.
- Activating a cell is an alternative to showing inline editor when the
- value can be edited in a simple way that doesn't warrant full editor
- control. The most typical use of cell activation is toggling the
- checkbox in wxDataViewToggleRenderer; others would be e.g. an embedded
- volume slider or a five-star rating column.
- The exact means of activating a cell are platform-dependent, but they
- are usually similar to those used for inline editing of values.
- Typically, a cell would be activated by Space or Enter keys or by left
- mouse click.
- @note Do not confuse this with item activation in wxDataViewCtrl
- and the wxEVT_DATAVIEW_ITEM_ACTIVATED event. That one is
- used for activating the item (or, to put it differently, the
- entire row) similarly to analogous messages in wxTreeCtrl and
- wxListCtrl, and the effect differs (play a song, open a file
- etc.). Cell activation, on the other hand, is all about
- interacting with the individual cell.
- @see wxDataViewCustomRenderer::ActivateCell()
- */
- wxDATAVIEW_CELL_ACTIVATABLE,
- /**
- Indicates that the user can edit the data in-place in an inline editor
- control that will show up when the user wants to edit the cell.
- A typical example of this behaviour is changing the filename in a file
- managers.
- Editing is typically triggered by slowly double-clicking the cell or by
- a platform-dependent keyboard shortcut (F2 is typical on Windows, Space
- and/or Enter is common elsewhere and supported on Windows too).
- @see wxDataViewCustomRenderer::CreateEditorCtrl()
- */
- wxDATAVIEW_CELL_EDITABLE
- };
- /**
- The values of this enum controls how a wxDataViewRenderer should display
- its contents in a cell.
- */
- enum wxDataViewCellRenderState
- {
- wxDATAVIEW_CELL_SELECTED = 1,
- wxDATAVIEW_CELL_PRELIT = 2,
- wxDATAVIEW_CELL_INSENSITIVE = 4,
- wxDATAVIEW_CELL_FOCUSED = 8
- };
- /**
- @class wxDataViewRenderer
- This class is used by wxDataViewCtrl to render the individual cells.
- One instance of a renderer class is owned by a wxDataViewColumn.
- There is a number of ready-to-use renderers provided:
- - wxDataViewTextRenderer,
- - wxDataViewIconTextRenderer,
- - wxDataViewToggleRenderer,
- - wxDataViewProgressRenderer,
- - wxDataViewBitmapRenderer,
- - wxDataViewDateRenderer,
- - wxDataViewSpinRenderer.
- - wxDataViewChoiceRenderer.
- Additionally, the user can write their own renderers by deriving from
- wxDataViewCustomRenderer.
- The ::wxDataViewCellMode and ::wxDataViewCellRenderState flags accepted
- by the constructors respectively controls what actions the cell data allows
- and how the renderer should display its contents in a cell.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewRenderer : public wxObject
- {
- public:
- /**
- Constructor.
- */
- wxDataViewRenderer(const wxString& varianttype,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int align = wxDVR_DEFAULT_ALIGNMENT );
- /**
- Enable or disable replacing parts of the item text with ellipsis to
- make it fit the column width.
- This method only makes sense for the renderers working with text, such
- as wxDataViewTextRenderer or wxDataViewIconTextRenderer.
- By default wxELLIPSIZE_MIDDLE is used.
- @param mode
- Ellipsization mode, use wxELLIPSIZE_NONE to disable.
- @since 2.9.1
- */
- void EnableEllipsize(wxEllipsizeMode mode = wxELLIPSIZE_MIDDLE);
- /**
- Disable replacing parts of the item text with ellipsis.
- If ellipsizing is disabled, the string will be truncated if it doesn't
- fit.
- This is the same as @code EnableEllipsize(wxELLIPSIZE_NONE) @endcode.
- @since 2.9.1
- */
- void DisableEllipsize();
- /**
- Returns the alignment. See SetAlignment()
- */
- virtual int GetAlignment() const;
- /**
- Returns the ellipsize mode used by the renderer.
- If the return value is wxELLIPSIZE_NONE, the text is simply truncated
- if it doesn't fit.
- @see EnableEllipsize()
- */
- wxEllipsizeMode GetEllipsizeMode() const;
- /**
- Returns the cell mode.
- */
- virtual wxDataViewCellMode GetMode() const;
- /**
- Returns pointer to the owning wxDataViewColumn.
- */
- wxDataViewColumn* GetOwner() const;
- /**
- This methods retrieves the value from the renderer in order to
- transfer the value back to the data model.
- Returns @false on failure.
- */
- virtual bool GetValue(wxVariant& value) const = 0;
- /**
- Returns a string with the type of the wxVariant supported by this renderer.
- */
- wxString GetVariantType() const;
- /**
- Sets the alignment of the renderer's content.
- The default value of @c wxDVR_DEFAULT_ALIGMENT indicates that the content
- should have the same alignment as the column header.
- The method is not implemented under OS X and the renderer always aligns
- its contents as the column header on that platform. The other platforms
- support both vertical and horizontal alignment.
- */
- virtual void SetAlignment( int align );
- /**
- Sets the owning wxDataViewColumn.
- This is usually called from within wxDataViewColumn.
- */
- void SetOwner(wxDataViewColumn* owner);
- /**
- Set the value of the renderer (and thus its cell) to @a value.
- The internal code will then render this cell with this data.
- */
- virtual bool SetValue(const wxVariant& value) = 0;
- /**
- Before data is committed to the data model, it is passed to this
- method where it can be checked for validity. This can also be
- used for checking a valid range or limiting the user input in
- a certain aspect (e.g. max number of characters or only alphanumeric
- input, ASCII only etc.). Return @false if the value is not valid.
- Please note that due to implementation limitations, this validation
- is done after the editing control already is destroyed and the
- editing process finished.
- */
- virtual bool Validate(wxVariant& value);
-
- virtual bool HasEditorCtrl() const;
- virtual wxWindow* CreateEditorCtrl(wxWindow * parent,
- wxRect labelRect,
- const wxVariant& value);
- virtual bool GetValueFromEditorCtrl(wxWindow * editor,
- wxVariant& value);
- virtual bool StartEditing( const wxDataViewItem &item, wxRect labelRect );
- virtual void CancelEditing();
- virtual bool FinishEditing();
- wxWindow *GetEditorCtrl();
- protected:
- wxDataViewCtrl* GetView() const;
- };
- /**
- @class wxDataViewTextRenderer
- wxDataViewTextRenderer is used for rendering text.
- It supports in-place editing if desired.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewTextRenderer : public wxDataViewRenderer
- {
- public:
- /**
- The ctor.
- */
- wxDataViewTextRenderer(const wxString& varianttype = "string",
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int align = wxDVR_DEFAULT_ALIGNMENT );
- };
- /**
- @class wxDataViewIconTextRenderer
- The wxDataViewIconTextRenderer class is used to display text with
- a small icon next to it as it is typically done in a file manager.
- This classes uses the wxDataViewIconText helper class to store its data.
- wxDataViewIconText can be converted to and from a wxVariant using the left
- shift operator.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewIconTextRenderer : public wxDataViewRenderer
- {
- public:
- /**
- The ctor.
- */
- wxDataViewIconTextRenderer(const wxString& varianttype = "wxDataViewIconText",
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int align = wxDVR_DEFAULT_ALIGNMENT );
- };
- /**
- @class wxDataViewProgressRenderer
- This class is used by wxDataViewCtrl to render progress bars.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewProgressRenderer : public wxDataViewRenderer
- {
- public:
- /**
- The ctor.
- */
- wxDataViewProgressRenderer(const wxString& label = wxEmptyString,
- const wxString& varianttype = "long",
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int align = wxDVR_DEFAULT_ALIGNMENT );
- };
- /**
- @class wxDataViewSpinRenderer
- This is a specialized renderer for rendering integer values.
- It supports modifying the values in-place by using a wxSpinCtrl.
- The renderer only support variants of type @e long.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewSpinRenderer : public wxDataViewCustomRenderer
- {
- public:
- /**
- Constructor.
- @a min and @a max indicate the minimum and maximum values for the wxSpinCtrl.
- */
- wxDataViewSpinRenderer(int min, int max,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_EDITABLE,
- int align = wxDVR_DEFAULT_ALIGNMENT);
- };
- /**
- @class wxDataViewToggleRenderer
- This class is used by wxDataViewCtrl to render toggle controls.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewToggleRenderer : public wxDataViewRenderer
- {
- public:
- /**
- The ctor.
- */
- wxDataViewToggleRenderer(const wxString& varianttype = "bool",
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int align = wxDVR_DEFAULT_ALIGNMENT);
- };
- /**
- A wxDataViewCtrl renderer using wxChoice control and values of strings in
- it.
- This class is used by wxDataViewCtrl to render choice controls.
- It stores a string so that SetValue() and GetValue() operate
- on a variant holding a string.
- @see wxDataViewChoiceByIndexRenderer
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewChoiceRenderer: public wxDataViewRenderer
- {
- public:
- /**
- The ctor.
- */
- wxDataViewChoiceRenderer( const wxArrayString &choices,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_EDITABLE,
- int alignment = wxDVR_DEFAULT_ALIGNMENT );
- /**
- Returns the choice referred to by index.
- */
- wxString GetChoice(size_t index) const;
- /**
- Returns all choices.
- */
- const wxArrayString& GetChoices() const;
- };
- /**
- A wxDataViewCtrl renderer using wxChoice control and indexes into it.
- Unlike its base wxDataViewChoiceRenderer class, this one stores the choice
- index, i.e. an @c int, in the variant used by its SetValue() and
- GetValue().
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewChoiceByIndexRenderer : public wxDataViewChoiceRenderer
- {
- public:
- /**
- The ctor.
- */
- wxDataViewChoiceByIndexRenderer( const wxArrayString &choices,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_EDITABLE,
- int alignment = wxDVR_DEFAULT_ALIGNMENT );
- };
- /**
- @class wxDataViewDateRenderer
- This class is used by wxDataViewCtrl to render calendar controls.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewDateRenderer : public wxDataViewRenderer
- {
- public:
- /**
- The ctor.
- */
- wxDataViewDateRenderer(const wxString& varianttype = "datetime",
- wxDataViewCellMode mode = wxDATAVIEW_CELL_ACTIVATABLE,
- int align = wxDVR_DEFAULT_ALIGNMENT);
- };
- /**
- @class wxDataViewCustomRenderer
- You need to derive a new class from wxDataViewCustomRenderer in
- order to write a new renderer.
- You need to override at least wxDataViewRenderer::SetValue, wxDataViewRenderer::GetValue,
- wxDataViewCustomRenderer::GetSize and wxDataViewCustomRenderer::Render.
- If you want your renderer to support in-place editing then you also need to override
- wxDataViewCustomRenderer::HasEditorCtrl, wxDataViewCustomRenderer::CreateEditorCtrl
- and wxDataViewCustomRenderer::GetValueFromEditorCtrl.
- Note that a special event handler will be pushed onto that editor control
- which handles @e \<ENTER\> and focus out events in order to end the editing.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewCustomRenderer : public wxDataViewRenderer
- {
- public:
- /**
- Constructor.
- */
- wxDataViewCustomRenderer(const wxString& varianttype = "string",
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int align = wxDVR_DEFAULT_ALIGNMENT);
- /**
- Destructor.
- */
- virtual ~wxDataViewCustomRenderer();
- /**
- Override this to react to cell @em activation. Activating a cell is an
- alternative to showing inline editor when the value can be edited in a
- simple way that doesn't warrant full editor control. The most typical
- use of cell activation is toggling the checkbox in
- wxDataViewToggleRenderer; others would be e.g. an embedded volume
- slider or a five-star rating column.
- The exact means of activating a cell are platform-dependent, but they
- are usually similar to those used for inline editing of values.
- Typically, a cell would be activated by Space or Enter keys or by left
- mouse click.
- This method will only be called if the cell has the
- wxDATAVIEW_CELL_ACTIVATABLE mode.
- @param cell
- Coordinates of the activated cell's area.
- @param model
- The model to manipulate in response.
- @param item
- Activated item.
- @param col
- Activated column of @a item.
- @param mouseEvent
- If the activation was triggered by mouse click, contains the
- corresponding event. Is @NULL otherwise (for keyboard activation).
- Mouse coordinates are adjusted to be relative to the cell.
- @since 2.9.3
- @note Do not confuse this method with item activation in wxDataViewCtrl
- and the wxEVT_DATAVIEW_ITEM_ACTIVATED event. That one is
- used for activating the item (or, to put it differently, the
- entire row) similarly to analogous messages in wxTreeCtrl and
- wxListCtrl, and the effect differs (play a song, open a file
- etc.). Cell activation, on the other hand, is all about
- interacting with the individual cell.
- @see CreateEditorCtrl()
- */
- virtual bool ActivateCell(const wxRect& cell,
- wxDataViewModel* model,
- const wxDataViewItem & item,
- unsigned int col,
- const wxMouseEvent *mouseEvent);
- /**
- Override this to create the actual editor control once editing
- is about to start.
- This method will only be called if the cell has the
- wxDATAVIEW_CELL_EDITABLE mode. Editing is typically triggered by slowly
- double-clicking the cell or by a platform-dependent keyboard shortcut
- (F2 is typical on Windows, Space and/or Enter is common elsewhere and
- supported on Windows too).
- @param parent
- The parent of the editor control.
- @param labelRect
- Indicates the position and size of the editor control. The control
- should be created in place of the cell and @a labelRect should be
- respected as much as possible.
- @param value
- Initial value of the editor.
- An example:
- @code
- {
- long l = value;
- return new wxSpinCtrl( parent, wxID_ANY, wxEmptyString,
- labelRect.GetTopLeft(), labelRect.GetSize(), 0, 0, 100, l );
- }
- @endcode
- @see ActivateCell()
- */
- virtual wxWindow* CreateEditorCtrl(wxWindow* parent,
- wxRect labelRect,
- const wxVariant& value);
- /**
- Return the attribute to be used for rendering.
- This function may be called from Render() implementation to use the
- attributes defined for the item if the renderer supports them.
- Notice that when Render() is called, the wxDC object passed to it is
- already set up to use the correct attributes (e.g. its font is set to
- bold or italic version if wxDataViewItemAttr::GetBold() or GetItalic()
- returns true) so it may not be necessary to call it explicitly if you
- only want to render text using the items attributes.
- @since 2.9.1
- */
- const wxDataViewItemAttr& GetAttr() const;
- /**
- Return size required to show content.
- */
- virtual wxSize GetSize() const = 0;
- /**
- Override this so that the renderer can get the value from the editor
- control (pointed to by @a editor):
- @code
- {
- wxSpinCtrl *sc = (wxSpinCtrl*) editor;
- long l = sc->GetValue();
- value = l;
- return true;
- }
- @endcode
- */
- virtual bool GetValueFromEditorCtrl(wxWindow* editor,
- wxVariant& value);
- /**
- Override this and make it return @true in order to
- indicate that this renderer supports in-place editing.
- */
- virtual bool HasEditorCtrl() const;
- /**
- Override this to react to a left click. This method will only be
- called in @c wxDATAVIEW_CELL_ACTIVATABLE mode. This method is
- deprecated, please use ActivateCell instead.
- */
- virtual bool LeftClick( wxPoint cursor,
- wxRect cell,
- wxDataViewModel * model,
- const wxDataViewItem & item,
- unsigned int col );
- /**
- Override this to react to the activation of a cell. This method is
- deprecated, please use ActivateCell instead.
- */
- virtual bool Activate(wxRect cell,
- wxDataViewModel * model,
- const wxDataViewItem & item,
- unsigned int col);
- /**
- Override this to render the cell.
- Before this is called, wxDataViewRenderer::SetValue was called
- so that this instance knows what to render.
- */
- virtual bool Render(wxRect cell, wxDC* dc, int state) = 0;
- /**
- This method should be called from within Render() whenever you need to
- render simple text.
- This will ensure that the correct colour, font and vertical alignment will
- be chosen so the text will look the same as text drawn by native renderers.
- */
- void RenderText(const wxString& text, int xoffset, wxRect cell,
- wxDC* dc, int state);
- /**
- Override this to start a drag operation. Not yet supported.
- */
- virtual bool StartDrag(const wxPoint& cursor,
- const wxRect& cell,
- wxDataViewModel* model,
- const wxDataViewItem & item,
- unsigned int col);
- protected:
- /**
- Helper for GetSize() implementations, respects attributes.
- */
- wxSize GetTextExtent(const wxString& str) const;
- };
- /**
- @class wxDataViewBitmapRenderer
- This class is used by wxDataViewCtrl to render bitmap controls.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewBitmapRenderer : public wxDataViewRenderer
- {
- public:
- /**
- The ctor.
- */
- wxDataViewBitmapRenderer(const wxString& varianttype = "wxBitmap",
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int align = wxDVR_DEFAULT_ALIGNMENT);
- };
- /**
- The flags used by wxDataViewColumn.
- Can be combined together.
- */
- enum wxDataViewColumnFlags
- {
- wxDATAVIEW_COL_RESIZABLE = 1,
- wxDATAVIEW_COL_SORTABLE = 2,
- wxDATAVIEW_COL_REORDERABLE = 4,
- wxDATAVIEW_COL_HIDDEN = 8
- };
- /**
- @class wxDataViewColumn
- This class represents a column in a wxDataViewCtrl.
- One wxDataViewColumn is bound to one column in the data model to which the
- wxDataViewCtrl has been associated.
- An instance of wxDataViewRenderer is used by this class to render its data.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewColumn : public wxSettableHeaderColumn
- {
- public:
- /**
- Constructs a text column.
- @param title
- The title of the column.
- @param renderer
- The class which will render the contents of this column.
- @param model_column
- The index of the model's column which is associated with this object.
- @param width
- The width of the column.
- The @c wxDVC_DEFAULT_WIDTH value is the fixed default value.
- @param align
- The alignment of the column title.
- @param flags
- One or more flags of the ::wxDataViewColumnFlags enumeration.
- */
- wxDataViewColumn(const wxString& title,
- wxDataViewRenderer* renderer,
- unsigned int model_column,
- int width = wxDVC_DEFAULT_WIDTH,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- /**
- Constructs a bitmap column.
- @param bitmap
- The bitmap of the column.
- @param renderer
- The class which will render the contents of this column.
- @param model_column
- The index of the model's column which is associated with this object.
- @param width
- The width of the column.
- The @c wxDVC_DEFAULT_WIDTH value is the fixed default value.
- @param align
- The alignment of the column title.
- @param flags
- One or more flags of the ::wxDataViewColumnFlags enumeration.
- */
- wxDataViewColumn(const wxBitmap& bitmap,
- wxDataViewRenderer* renderer,
- unsigned int model_column,
- int width = wxDVC_DEFAULT_WIDTH,
- wxAlignment align = wxALIGN_CENTER,
- int flags = wxDATAVIEW_COL_RESIZABLE);
- /**
- Returns the index of the column of the model, which this
- wxDataViewColumn is displaying.
- */
- unsigned int GetModelColumn() const;
- /**
- Returns the owning wxDataViewCtrl.
- */
- wxDataViewCtrl* GetOwner() const;
- /**
- Returns the renderer of this wxDataViewColumn.
- @see wxDataViewRenderer.
- */
- wxDataViewRenderer* GetRenderer() const;
- };
- /**
- @class wxDataViewListCtrl
- This class is a wxDataViewCtrl which internally uses a wxDataViewListStore
- and forwards most of its API to that class.
- The purpose of this class is to offer a simple way to display and
- edit a small table of data without having to write your own wxDataViewModel.
- @code
- wxDataViewListCtrl *listctrl = new wxDataViewListCtrl( parent, wxID_ANY );
- listctrl->AppendToggleColumn( "Toggle" );
- listctrl->AppendTextColumn( "Text" );
- wxVector<wxVariant> data;
- data.push_back( wxVariant(true) );
- data.push_back( wxVariant("row 1") );
- listctrl->AppendItem( data );
- data.clear();
- data.push_back( wxVariant(false) );
- data.push_back( wxVariant("row 3") );
- listctrl->AppendItem( data );
- @endcode
- @beginStyleTable
- See wxDataViewCtrl for the list of supported styles.
- @endStyleTable
- @beginEventEmissionTable
- See wxDataViewCtrl for the list of events emitted by this class.
- @endEventTable
- @library{wxadv}
- @category{ctrl,dvc}
- @since 2.9.0
- */
- class wxDataViewListCtrl: public wxDataViewCtrl
- {
- public:
- /**
- Default ctor.
- */
- wxDataViewListCtrl();
- /**
- Constructor. Calls Create().
- */
- wxDataViewListCtrl( wxWindow *parent, wxWindowID id,
- const wxPoint& pos = wxDefaultPosition,
- const wxSize& size = wxDefaultSize, long style = wxDV_ROW_LINES,
- const wxValidator& validator = wxDefaultValidator );
- /**
- Destructor. Deletes the image list if any.
- */
- ~wxDataViewListCtrl();
- /**
- Creates the control and a wxDataViewListStore as its internal model.
- */
- bool Create( wxWindow *parent, wxWindowID id,
- const wxPoint& pos = wxDefaultPosition,
- const wxSize& size = wxDefaultSize, long style = wxDV_ROW_LINES,
- const wxValidator& validator = wxDefaultValidator );
- //@{
- /**
- Returns the store.
- */
- wxDataViewListStore *GetStore();
- const wxDataViewListStore *GetStore() const;
- //@}
- /**
- Returns the position of given @e item or wxNOT_FOUND if it's
- not a valid item.
- @since 2.9.2
- */
- int ItemToRow(const wxDataViewItem &item) const;
- /**
- Returns the wxDataViewItem at the given @e row.
- @since 2.9.2
- */
- wxDataViewItem RowToItem(int row) const;
- //@{
- /**
- @name Selection handling functions
- */
- /**
- Returns index of the selected row or wxNOT_FOUND.
- @see wxDataViewCtrl::GetSelection()
- @since 2.9.2
- */
- int GetSelectedRow() const;
- /**
- Selects given row.
- @see wxDataViewCtrl::Select()
- @since 2.9.2
- */
- void SelectRow(unsigned row);
- /**
- Unselects given row.
- @see wxDataViewCtrl::Unselect()
- @since 2.9.2
- */
- void UnselectRow(unsigned row);
- /**
- Returns true if @a row is selected.
- @see wxDataViewCtrl::IsSelected()
- @since 2.9.2
- */
- bool IsRowSelected(unsigned row) const;
- //@}
- /**
- @name Column management functions
- */
- //@{
- /**
- Appends a column to the control and additionally appends a
- column to the store with the type string.
- */
- virtual bool AppendColumn( wxDataViewColumn *column );
- /**
- Appends a column to the control and additionally appends a
- column to the list store with the type @a varianttype.
- */
- void AppendColumn( wxDataViewColumn *column, const wxString &varianttype );
- /**
- Appends a text column to the control and the store.
- See wxDataViewColumn::wxDataViewColumn for more info about
- the parameters.
- */
- wxDataViewColumn *AppendTextColumn( const wxString &label,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1, wxAlignment align = wxALIGN_LEFT,
- int flags = wxDATAVIEW_COL_RESIZABLE );
- /**
- Appends a toggle column to the control and the store.
- See wxDataViewColumn::wxDataViewColumn for more info about
- the parameters.
- */
- wxDataViewColumn *AppendToggleColumn( const wxString &label,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_ACTIVATABLE,
- int width = -1, wxAlignment align = wxALIGN_LEFT,
- int flags = wxDATAVIEW_COL_RESIZABLE );
- /**
- Appends a progress column to the control and the store.
- See wxDataViewColumn::wxDataViewColumn for more info about
- the parameters.
- */
- wxDataViewColumn *AppendProgressColumn( const wxString &label,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1, wxAlignment align = wxALIGN_LEFT,
- int flags = wxDATAVIEW_COL_RESIZABLE );
- /**
- Appends an icon-and-text column to the control and the store.
- See wxDataViewColumn::wxDataViewColumn for more info about
- the parameters.
- */
- wxDataViewColumn *AppendIconTextColumn( const wxString &label,
- wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
- int width = -1, wxAlignment align = wxALIGN_LEFT,
- int flags = wxDATAVIEW_COL_RESIZABLE );
- /**
- Inserts a column to the control and additionally inserts a
- column to the store with the type string.
- */
- virtual bool InsertColumn( unsigned int pos, wxDataViewColumn *column );
- /**
- Inserts a column to the control and additionally inserts a
- column to the list store with the type @a varianttype.
- */
- void InsertColumn( unsigned int pos, wxDataViewColumn *column,
- const wxString &varianttype );
- /**
- Prepends a column to the control and additionally prepends a
- column to the store with the type string.
- */
- virtual bool PrependColumn( wxDataViewColumn *column );
- /**
- Prepends a column to the control and additionally prepends a
- column to the list store with the type @a varianttype.
- */
- void PrependColumn( wxDataViewColumn *column, const wxString &varianttype );
- //@}
- /**
- @name Item management functions
- */
- //@{
- /**
- Appends an item (=row) to the control and store.
- */
- void AppendItem( const wxVector<wxVariant> &values, wxUIntPtr data = NULL );
- /**
- Prepends an item (=row) to the control and store.
- */
- void PrependItem( const wxVector<wxVariant> &values, wxUIntPtr data = NULL );
- /**
- Inserts an item (=row) to the control and store.
- */
- void InsertItem( unsigned int row, const wxVector<wxVariant> &values, wxUIntPtr data = NULL );
- /**
- Delete the row at position @a row.
- */
- void DeleteItem( unsigned row );
- /**
- Delete all items (= all rows).
- */
- void DeleteAllItems();
- /**
- Returns the number of items (=rows) in the control
- @since 2.9.4
- */
- unsigned int GetItemCount() const;
- /**
- Returns the client data associated with the item.
- @see SetItemData()
- @since 2.9.4
- */
- wxUIntPtr GetItemData(const wxDataViewItem& item) const;
- /**
- Sets the value in the store and update the control.
- */
- void SetValue( const wxVariant &value, unsigned int row, unsigned int col );
- /**
- Returns the value from the store.
- */
- void GetValue( wxVariant &value, unsigned int row, unsigned int col );
- /**
- Sets the value in the store and update the control.
- This method assumes that the string is stored in respective
- column.
- */
- void SetTextValue( const wxString &value, unsigned int row, unsigned int col );
- /**
- Returns the value from the store.
- This method assumes that the string is stored in respective
- column.
- */
- wxString GetTextValue( unsigned int row, unsigned int col ) const;
- /**
- Sets the value in the store and update the control.
- This method assumes that the boolean value is stored in
- respective column.
- */
- void SetToggleValue( bool value, unsigned int row, unsigned int col );
- /**
- Returns the value from the store.
- This method assumes that the boolean value is stored in
- respective column.
- */
- bool GetToggleValue( unsigned int row, unsigned int col ) const;
- /**
- Associates a client data pointer with the given item.
- Notice that the control does @e not take ownership of the pointer for
- compatibility with wxListCtrl. I.e. it will @e not delete the pointer
- (if it is a pointer and not a number) itself, it is up to you to do it.
- @see GetItemData()
- @since 2.9.4
- */
- void SetItemData(const wxDataViewItem& item, wxUIntPtr data);
- //@}
- };
- /**
- @class wxDataViewTreeCtrl
- This class is a wxDataViewCtrl which internally uses a wxDataViewTreeStore
- and forwards most of its API to that class.
- Additionally, it uses a wxImageList to store a list of icons.
- The main purpose of this class is to provide a simple upgrade path for code
- using wxTreeCtrl.
- @beginStyleTable
- See wxDataViewCtrl for the list of supported styles.
- @endStyleTable
- @beginEventEmissionTable
- See wxDataViewCtrl for the list of events emitted by this class.
- @endEventTable
- @library{wxadv}
- @category{ctrl,dvc}
- @since 2.9.0
- @appearance{dataviewtreectrl}
- */
- class wxDataViewTreeCtrl : public wxDataViewCtrl
- {
- public:
- /**
- Default ctor.
- */
- wxDataViewTreeCtrl();
- /**
- Constructor.
- Calls Create().
- */
- wxDataViewTreeCtrl(wxWindow* parent, wxWindowID id,
- const wxPoint& pos = wxDefaultPosition,
- const wxSize& size = wxDefaultSize,
- long style = wxDV_NO_HEADER | wxDV_ROW_LINES,
- const wxValidator& validator = wxDefaultValidator);
- /**
- Destructor. Deletes the image list if any.
- */
- virtual ~wxDataViewTreeCtrl();
- /**
- Appends a container to the given @a parent.
- */
- wxDataViewItem AppendContainer(const wxDataViewItem& parent,
- const wxString& text,
- int icon = -1,
- int expanded = -1,
- wxClientData* data = NULL);
- /**
- Appends an item to the given @a parent.
- */
- wxDataViewItem AppendItem(const wxDataViewItem& parent,
- const wxString& text,
- int icon = -1,
- wxClientData* data = NULL);
- /**
- Creates the control and a wxDataViewTreeStore as its internal model.
- The default tree column created by this method is an editable column
- using wxDataViewIconTextRenderer as its renderer.
- */
- bool Create(wxWindow* parent, wxWindowID id,
- const wxPoint& pos = wxDefaultPosition,
- const wxSize& size = wxDefaultSize,
- long style = wxDV_NO_HEADER | wxDV_ROW_LINES,
- const wxValidator& validator = wxDefaultValidator);
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- void DeleteAllItems();
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- void DeleteChildren(const wxDataViewItem& item);
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- void DeleteItem(const wxDataViewItem& item);
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- int GetChildCount(const wxDataViewItem& parent) const;
- /**
- Returns the image list.
- */
- wxImageList* GetImageList();
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- wxClientData* GetItemData(const wxDataViewItem& item) const;
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- const wxIcon& GetItemExpandedIcon(const wxDataViewItem& item) const;
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- const wxIcon& GetItemIcon(const wxDataViewItem& item) const;
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- wxString GetItemText(const wxDataViewItem& item) const;
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- wxDataViewItem GetNthChild(const wxDataViewItem& parent,
- unsigned int pos) const;
- //@{
- /**
- Returns the store.
- */
- wxDataViewTreeStore* GetStore();
- const wxDataViewTreeStore* GetStore() const;
- //@}
- /**
- Calls the same method from wxDataViewTreeStore but uses
- an index position in the image list instead of a wxIcon.
- */
- wxDataViewItem InsertContainer(const wxDataViewItem& parent,
- const wxDataViewItem& previous,
- const wxString& text,
- int icon = -1,
- int expanded = -1,
- wxClientData* data = NULL);
- /**
- Calls the same method from wxDataViewTreeStore but uses
- an index position in the image list instead of a wxIcon.
- */
- wxDataViewItem InsertItem(const wxDataViewItem& parent,
- const wxDataViewItem& previous,
- const wxString& text,
- int icon = -1,
- wxClientData* data = NULL);
- /**
- Returns true if item is a container.
- */
- bool IsContainer( const wxDataViewItem& item );
-
- /**
- Calls the same method from wxDataViewTreeStore but uses
- an index position in the image list instead of a wxIcon.
- */
- wxDataViewItem PrependContainer(const wxDataViewItem& parent,
- const wxString& text,
- int icon = -1,
- int expanded = -1,
- wxClientData* data = NULL);
- /**
- Calls the same method from wxDataViewTreeStore but uses
- an index position in the image list instead of a wxIcon.
- */
- wxDataViewItem PrependItem(const wxDataViewItem& parent,
- const wxString& text,
- int icon = -1,
- wxClientData* data = NULL);
- /**
- Sets the image list.
- */
- void SetImageList(wxImageList* imagelist);
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- void SetItemData(const wxDataViewItem& item, wxClientData* data);
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- void SetItemExpandedIcon(const wxDataViewItem& item,
- const wxIcon& icon);
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- void SetItemIcon(const wxDataViewItem& item, const wxIcon& icon);
- /**
- Calls the identical method from wxDataViewTreeStore.
- */
- void SetItemText(const wxDataViewItem& item,
- const wxString& text);
- };
- /**
- @class wxDataViewListStore
- wxDataViewListStore is a specialised wxDataViewModel for storing
- a simple table of data. Since it derives from wxDataViewIndexListModel
- its data is be accessed by row (i.e. by index) instead of only
- by wxDataViewItem.
- This class actually stores the values (therefore its name)
- and implements all virtual methods from the base classes so it can be
- used directly without having to derive any class from it, but it is
- mostly used from within wxDataViewListCtrl.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewListStore: public wxDataViewIndexListModel
- {
- public:
- /**
- Constructor
- */
- wxDataViewListStore();
- /**
- Destructor
- */
- ~wxDataViewListStore();
- /**
- Prepends a data column.
- @a variantype indicates the type of values store in the column.
- This does not automatically fill in any (default) values in
- rows which exist in the store already.
- */
- void PrependColumn( const wxString &varianttype );
- /**
- Inserts a data column before @a pos.
- @a variantype indicates the type of values store in the column.
- This does not automatically fill in any (default) values in
- rows which exist in the store already.
- */
- void InsertColumn( unsigned int pos, const wxString &varianttype );
- /**
- Appends a data column.
- @a variantype indicates the type of values store in the column.
- This does not automatically fill in any (default) values in
- rows which exist in the store already.
- */
- void AppendColumn( const wxString &varianttype );
- /**
- Appends an item (=row) and fills it with @a values.
- The values must match the values specifies in the column
- in number and type. No (default) values are filled in
- automatically.
- */
- void AppendItem( const wxVector<wxVariant> &values, wxUIntPtr data = NULL );
- /**
- Prepends an item (=row) and fills it with @a values.
- The values must match the values specifies in the column
- in number and type. No (default) values are filled in
- automatically.
- */
- void PrependItem( const wxVector<wxVariant> &values, wxUIntPtr data = NULL );
- /**
- Inserts an item (=row) and fills it with @a values.
- The values must match the values specifies in the column
- in number and type. No (default) values are filled in
- automatically.
- */
- void InsertItem( unsigned int row, const wxVector<wxVariant> &values, wxUIntPtr data = NULL );
- /**
- Delete the item (=row) at position @a pos.
- */
- void DeleteItem( unsigned pos );
- /**
- Delete all item (=all rows) in the store.
- */
- void DeleteAllItems();
- /**
- Returns the number of items (=rows) in the control
- @since 2.9.4
- */
- unsigned int GetItemCount() const;
- /**
- Returns the client data associated with the item.
- @see SetItemData()
- @since 2.9.4
- */
- wxUIntPtr GetItemData(const wxDataViewItem& item) const;
- /**
- Overridden from wxDataViewModel
- */
- virtual unsigned int GetColumnCount() const;
- /**
- Overridden from wxDataViewModel
- */
- virtual wxString GetColumnType( unsigned int col ) const;
- /**
- Sets the client data associated with the item.
- Notice that this class does @e not take ownership of the passed in
- pointer and will not delete it.
- @see GetItemData()
- @since 2.9.4
- */
- void SetItemData(const wxDataViewItem& item, wxUIntPtr data);
- /**
- Overridden from wxDataViewIndexListModel
- */
- virtual void GetValueByRow( wxVariant &value,
- unsigned int row, unsigned int col ) const;
- /**
- Overridden from wxDataViewIndexListModel
- */
- virtual bool SetValueByRow( const wxVariant &value,
- unsigned int row, unsigned int col );
- };
- /**
- @class wxDataViewTreeStore
- wxDataViewTreeStore is a specialised wxDataViewModel for storing simple
- trees very much like wxTreeCtrl does and it offers a similar API.
- This class actually stores the entire tree and the values (therefore its name)
- and implements all virtual methods from the base class so it can be used directly
- without having to derive any class from it, but it is mostly used from within
- wxDataViewTreeCtrl.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewTreeStore : public wxDataViewModel
- {
- public:
- /**
- Constructor. Creates the invisible root node internally.
- */
- wxDataViewTreeStore();
- /**
- Destructor.
- */
- virtual ~wxDataViewTreeStore();
- /**
- Append a container.
- */
- wxDataViewItem AppendContainer(const wxDataViewItem& parent,
- const wxString& text,
- const wxIcon& icon = wxNullIcon,
- const wxIcon& expanded = wxNullIcon,
- wxClientData* data = NULL);
- /**
- Append an item.
- */
- wxDataViewItem AppendItem(const wxDataViewItem& parent,
- const wxString& text,
- const wxIcon& icon = wxNullIcon,
- wxClientData* data = NULL);
- /**
- Delete all item in the model.
- */
- void DeleteAllItems();
- /**
- Delete all children of the item, but not the item itself.
- */
- void DeleteChildren(const wxDataViewItem& item);
- /**
- Delete this item.
- */
- void DeleteItem(const wxDataViewItem& item);
- /**
- Return the number of children of item.
- */
- int GetChildCount(const wxDataViewItem& parent) const;
- /**
- Returns the client data associated with the item.
- */
- wxClientData* GetItemData(const wxDataViewItem& item) const;
- /**
- Returns the icon to display in expanded containers.
- */
- const wxIcon& GetItemExpandedIcon(const wxDataViewItem& item) const;
- /**
- Returns the icon of the item.
- */
- const wxIcon& GetItemIcon(const wxDataViewItem& item) const;
- /**
- Returns the text of the item.
- */
- wxString GetItemText(const wxDataViewItem& item) const;
- /**
- Returns the nth child item of item.
- */
- wxDataViewItem GetNthChild(const wxDataViewItem& parent,
- unsigned int pos) const;
- /**
- Inserts a container after @a previous.
- */
- wxDataViewItem InsertContainer(const wxDataViewItem& parent,
- const wxDataViewItem& previous,
- const wxString& text,
- const wxIcon& icon = wxNullIcon,
- const wxIcon& expanded = wxNullIcon,
- wxClientData* data = NULL);
- /**
- Inserts an item after @a previous.
- */
- wxDataViewItem InsertItem(const wxDataViewItem& parent,
- const wxDataViewItem& previous,
- const wxString& text,
- const wxIcon& icon = wxNullIcon,
- wxClientData* data = NULL);
- /**
- Inserts a container before the first child item or @a parent.
- */
- wxDataViewItem PrependContainer(const wxDataViewItem& parent,
- const wxString& text,
- const wxIcon& icon = wxNullIcon,
- const wxIcon& expanded = wxNullIcon,
- wxClientData* data = NULL);
- /**
- Inserts an item before the first child item or @a parent.
- */
- wxDataViewItem PrependItem(const wxDataViewItem& parent,
- const wxString& text,
- const wxIcon& icon = wxNullIcon,
- wxClientData* data = NULL);
- /**
- Sets the client data associated with the item.
- */
- void SetItemData(const wxDataViewItem& item, wxClientData* data);
- /**
- Sets the expanded icon for the item.
- */
- void SetItemExpandedIcon(const wxDataViewItem& item,
- const wxIcon& icon);
- /**
- Sets the icon for the item.
- */
- void SetItemIcon(const wxDataViewItem& item, const wxIcon& icon);
- };
- /**
- @class wxDataViewIconText
- wxDataViewIconText is used by wxDataViewIconTextRenderer for data transfer.
- This class can be converted to and from a wxVariant.
- @library{wxadv}
- @category{dvc}
- */
- class wxDataViewIconText : public wxObject
- {
- public:
- //@{
- /**
- Constructor.
- */
- wxDataViewIconText(const wxString& text = wxEmptyString,
- const wxIcon& icon = wxNullIcon);
- wxDataViewIconText(const wxDataViewIconText& other);
- //@}
- /**
- Gets the icon.
- */
- const wxIcon& GetIcon() const;
- /**
- Gets the text.
- */
- wxString GetText() const;
- /**
- Set the icon.
- */
- void SetIcon(const wxIcon& icon);
- /**
- Set the text.
- */
- void SetText(const wxString& text);
- };
- /**
- @class wxDataViewEvent
- This is the event class for the wxDataViewCtrl notifications.
- @beginEventTable{wxDataViewEvent}
- @event{EVT_DATAVIEW_SELECTION_CHANGED(id, func)}
- Process a @c wxEVT_DATAVIEW_SELECTION_CHANGED event.
- @event{EVT_DATAVIEW_ITEM_ACTIVATED(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_ACTIVATED event.
- @event{EVT_DATAVIEW_ITEM_EDITING_STARTED(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_EDITING_STARTED event.
- @event{EVT_DATAVIEW_ITEM_EDITING_DONE(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_EDITING_DONE event.
- @event{EVT_DATAVIEW_ITEM_COLLAPSING(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_COLLAPSING event.
- @event{EVT_DATAVIEW_ITEM_COLLAPSED(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_COLLAPSED event.
- @event{EVT_DATAVIEW_ITEM_EXPANDING(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_EXPANDING event.
- @event{EVT_DATAVIEW_ITEM_EXPANDED(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_EXPANDED event.
- @event{EVT_DATAVIEW_ITEM_VALUE_CHANGED(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_VALUE_CHANGED event.
- @event{EVT_DATAVIEW_ITEM_CONTEXT_MENU(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_CONTEXT_MENU event.
- @event{EVT_DATAVIEW_COLUMN_HEADER_CLICK(id, func)}
- Process a @c wxEVT_DATAVIEW_COLUMN_HEADER_CLICK event.
- @event{EVT_DATAVIEW_COLUMN_HEADER_RIGHT_CLICK(id, func)}
- Process a @c wxEVT_DATAVIEW_COLUMN_HEADER_RIGHT_CLICK event.
- @event{EVT_DATAVIEW_COLUMN_SORTED(id, func)}
- Process a @c wxEVT_DATAVIEW_COLUMN_SORTED event.
- @event{EVT_DATAVIEW_COLUMN_REORDERED(id, func)}
- Process a @c wxEVT_DATAVIEW_COLUMN_REORDERED event.
- Currently this even is only generated when using the native OSX
- version.
- @event{EVT_DATAVIEW_ITEM_BEGIN_DRAG(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_BEGIN_DRAG event.
- @event{EVT_DATAVIEW_ITEM_DROP_POSSIBLE(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_DROP_POSSIBLE event.
- @event{EVT_DATAVIEW_ITEM_DROP(id, func)}
- Process a @c wxEVT_DATAVIEW_ITEM_DROP event.
- @event{EVT_DATAVIEW_CACHE_HINT(id, func)}
- Process a @c wxEVT_DATAVIEW_CACHE_HINT event.
- @endEventTable
- @library{wxadv}
- @category{events,dvc}
- */
- class wxDataViewEvent : public wxNotifyEvent
- {
- public:
- /**
- Constructor. Typically used by wxWidgets internals only.
- */
- wxDataViewEvent(wxEventType commandType = wxEVT_NULL,
- int winid = 0);
- /**
- Returns the position of the column in the control or -1
- if no column field was set by the event emitter.
- */
- int GetColumn() const;
- /**
- Returns a pointer to the wxDataViewColumn from which
- the event was emitted or @NULL.
- */
- wxDataViewColumn* GetDataViewColumn() const;
- /**
- Returns the wxDataViewModel associated with the event.
- */
- wxDataViewModel* GetModel() const;
- /**
- Returns the position of a context menu event in screen coordinates.
- */
- wxPoint GetPosition() const;
- /**
- Returns a reference to a value.
- */
- const wxVariant& GetValue() const;
- /**
- Can be used to determine whether the new value is going to be accepted
- in wxEVT_DATAVIEW_ITEM_EDITING_DONE handler.
- Returns @true if editing the item was cancelled or if the user tried to
- enter an invalid value (refused by wxDataViewRenderer::Validate()). If
- this method returns @false, it means that the value in the model is
- about to be changed to the new one.
- Notice that wxEVT_DATAVIEW_ITEM_EDITING_DONE event handler can
- call wxNotifyEvent::Veto() to prevent this from happening.
- Currently support for setting this field and for vetoing the change is
- only available in the generic version of wxDataViewCtrl, i.e. under MSW
- but not GTK nor OS X.
- @since 2.9.3
- */
- bool IsEditCancelled() const;
- /**
- Sets the column index associated with this event.
- */
- void SetColumn(int col);
- /**
- For @c wxEVT_DATAVIEW_COLUMN_HEADER_CLICK only.
- */
- void SetDataViewColumn(wxDataViewColumn* col);
- /**
- Sets the dataview model associated with this event.
- */
- void SetModel(wxDataViewModel* model);
- /**
- Sets the value associated with this event.
- */
- void SetValue(const wxVariant& value);
- /**
- Set wxDataObject for data transfer within a drag operation.
- */
- void SetDataObject( wxDataObject *obj );
- /**
- Gets the wxDataFormat during a drop operation.
- */
- wxDataFormat GetDataFormat() const;
- /**
- Gets the data size for a drop data transfer.
- */
- size_t GetDataSize() const;
- /**
- Gets the data buffer for a drop data transfer.
- */
- void *GetDataBuffer() const;
- /**
- Specify the kind of the drag operation to perform.
- This method can be used inside a wxEVT_DATAVIEW_ITEM_BEGIN_DRAG
- handler in order to configure the drag operation. Valid values are
- ::wxDrag_CopyOnly (default), ::wxDrag_AllowMove (allow the data to be
- moved) and ::wxDrag_DefaultMove.
- Currently it is only honoured by the generic version of wxDataViewCtrl
- (used e.g. under MSW) and not supported by the native GTK and OS X
- versions.
- @see GetDropEffect()
- @since 2.9.4
- */
- void SetDragFlags(int flags);
- /**
- Returns the effect the user requested to happen to the dropped data.
- This function can be used inside
- wxEVT_DATAVIEW_ITEM_DROP_POSSIBLE and
- wxEVT_DATAVIEW_ITEM_DROP handlers and returns whether the user
- is trying to copy (the return value is ::wxDragCopy) or move (if the
- return value is ::wxDragMove) the data.
- Currently this is only available when using the generic version of
- wxDataViewCtrl (used e.g. under MSW) and always returns ::wxDragNone in
- the GTK and OS X native versions.
- @since 2.9.4
- */
- wxDragResult GetDropEffect() const;
- /**
- Return the first row that will be displayed.
- */
- int GetCacheFrom() const;
- /**
- Return the last row that will be displayed.
- */
- int GetCacheTo() const;
-
- wxDataViewItem GetItem() const;
- void SetItem( const wxDataViewItem &item );
- void SetEditCanceled(bool editCancelled);
- void SetPosition( int x, int y );
- void SetCache(int from, int to);
- wxDataObject *GetDataObject() const;
- void SetDataFormat( const wxDataFormat &format );
- void SetDataSize( size_t size );
- void SetDataBuffer( void* buf );
- int GetDragFlags() const;
- void SetDropEffect( wxDragResult effect );
- };
|