本文整理汇总了C++中metadb_handle_list_cref::get_count方法的典型用法代码示例。如果您正苦于以下问题:C++ metadb_handle_list_cref::get_count方法的具体用法?C++ metadb_handle_list_cref::get_count怎么用?C++ metadb_handle_list_cref::get_count使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类metadb_handle_list_cref
的用法示例。
在下文中一共展示了metadb_handle_list_cref::get_count方法的13个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: context_command
virtual void context_command(unsigned int p_index, metadb_handle_list_cref p_data, const GUID& p_caller)
{
if(p_index == 0 && p_data.get_count() == 1)
AlsongLyricLinkDialog::OpenLyricLinkDialog(core_api::get_main_window(), p_data.get_item(0));
else if(p_index == 1 && p_data.get_count() == 1)
LyricSyncDialog::Open(p_data.get_item(0), core_api::get_main_window());
}
示例2: context_get_display
virtual bool context_get_display(unsigned int p_index, metadb_handle_list_cref p_data, pfc::string_base & p_out, unsigned & p_displayflags, const GUID & p_caller)
{
if(p_index == 0)
{
p_out = EncodingFunc::ToUTF8(TEXT("알송 가사 추가/변경")).c_str();
return p_data.get_count() == 1;
}
else if(p_index == 1)
{
p_out = EncodingFunc::ToUTF8(TEXT("가사 싱크 수정")).c_str();
return p_data.get_count() == 1;
}
return false;
}
示例3: sort_by_relative_path_get_order
void metadb_handle_list_helper::sort_by_relative_path_get_order(metadb_handle_list_cref p_list,t_size* order)
{
const t_size count = p_list.get_count();
t_size n;
pfc::array_t<custom_sort_data> data;
data.set_size(count);
static_api_ptr_t<library_manager> api;
pfc::string8_fastalloc temp;
temp.prealloc(512);
for(n=0;n<count;n++)
{
metadb_handle_ptr item;
p_list.get_item_ex(item,n);
if (!api->get_relative_path(item,temp)) temp = "";
data[n].index = n;
data[n].text = makeSortString(temp);
//data[n].subsong = item->get_subsong_index();
}
pfc::sort_t(data,custom_sort_compare<1>,count);
//qsort(data.get_ptr(),count,sizeof(custom_sort_data),(int (__cdecl *)(const void *elem1, const void *elem2 ))custom_sort_compare);
for(n=0;n<count;n++)
{
order[n]=data[n].index;
delete[] data[n].text;
}
}
示例4: sort_by_format_get_order
void metadb_handle_list_helper::sort_by_format_get_order(metadb_handle_list_cref p_list,t_size* order,const service_ptr_t<titleformat_object> & p_script,titleformat_hook * p_hook,int p_direction)
{
// pfc::hires_timer timer; timer.start();
const t_size count = p_list.get_count();
pfc::array_t<custom_sort_data> data; data.set_size(count);
{
pfc::counter counter(0);
pfc::array_t<pfc::rcptr_t<tfthread> > threads; threads.set_size(pfc::getOptimalWorkerThreadCountEx(p_list.get_count() / 128));
PFC_ASSERT( threads.get_size() > 0 );
for(t_size walk = 0; walk < threads.get_size(); ++walk) {
threads[walk].new_t(&counter,p_list,data.get_ptr(),p_script,p_hook);
}
for(t_size walk = 1; walk < threads.get_size(); ++walk) threads[walk]->start();
threads[0]->threadProc();
for(t_size walk = 1; walk < threads.get_size(); ++walk) threads[walk]->waitTillDone();
}
// console::formatter() << "metadb_handle sort: prepared in " << pfc::format_time_ex(timer.query(),6);
pfc::sort_t(data, p_direction > 0 ? custom_sort_compare<1> : custom_sort_compare<-1>,count);
//qsort(data.get_ptr(),count,sizeof(custom_sort_data),p_direction > 0 ? _custom_sort_compare<1> : _custom_sort_compare<-1>);
// console::formatter() << "metadb_handle sort: sorted in " << pfc::format_time_ex(timer.query(),6);
for(t_size n=0;n<count;n++)
{
order[n]=data[n].index;
delete[] data[n].text;
}
// console::formatter() << "metadb_handle sort: finished in " << pfc::format_time_ex(timer.query(),6);
}
示例5:
virtual void
context_command(
unsigned int index,
metadb_handle_list_cref tracks,
const GUID& /*caller*/
)
{
switch(index)
{
case Items::GetArtistTopTracks:
{
generateArtistPlaylist(tracks);
break;
}
case Items::GetSimilarTracks:
{
if(tracks.get_count() > 0)
{
generateSimilarTracksPlaylist(tracks.get_item(0));
}
break;
}
default:
{
uBugCheck();
}
}
}
示例6: extract_single_path
bool metadb_handle_list_helper::extract_single_path(metadb_handle_list_cref list, const char * &pathOut) {
const t_size total = list.get_count();
if (total == 0) return false;
const char * path = list[0]->get_path();
for(t_size walk = 1; walk < total; ++walk) {
if (metadb::path_compare(path, list[walk]->get_path()) != 0) return false;
}
pathOut = path;
return true;
}
示例7: calc_total_duration
double metadb_handle_list_helper::calc_total_duration(metadb_handle_list_cref p_list)
{
double ret = 0;
t_size n, m = p_list.get_count();
for(n=0;n<m;n++)
{
double temp = p_list.get_item(n)->get_length();
if (temp > 0) ret += temp;
}
return ret;
}
示例8: on_files_rechaptered
void playlist_manager::on_files_rechaptered( metadb_handle_list_cref newHandles ) {
pfc::map_t< const char*, metadb_handle_list, metadb::path_comparator > byPath;
const size_t total = newHandles.get_count();
for( size_t w = 0; w < total; ++w ) {
auto handle = newHandles[w];
byPath[ handle->get_path() ] += handle;
}
for( auto iter = byPath.first(); iter.is_valid(); ++ iter ) {
this->on_file_rechaptered( iter->m_key, iter->m_value );
}
}
示例9: RunCalculatePeak
void RunCalculatePeak(metadb_handle_list_cref data) {
try {
if (data.get_count() == 0) throw pfc::exception_invalid_params();
service_ptr_t<threaded_process_callback> cb = new service_impl_t<calculate_hash>(data);
static_api_ptr_t<threaded_process>()->run_modeless(
cb,
threaded_process::flag_show_progress_dual | threaded_process::flag_show_item | threaded_process::flag_show_abort,
core_api::get_main_window(),
"Calculating audio data hashes...");
} catch(std::exception const & e) {
popup_message::g_complain("Could not start audio hashing process", e);
}
}
示例10: on_selection_changed
void nonautoregister_callbacks::on_selection_changed(metadb_handle_list_cref p_selection)
{
if (p_selection.get_count() > 0)
{
simple_callback_data<metadb_handle_ptr>* on_selection_changed_data
= new simple_callback_data<metadb_handle_ptr>(p_selection[0]);
panel_manager::instance().post_msg_to_all_pointer(CALLBACK_UWM_ON_SELECTION_CHANGED, on_selection_changed_data);
}
else
{
panel_manager::instance().post_msg_to_all(CALLBACK_UWM_ON_SELECTION_CHANGED);
}
}
示例11: getMainArtist
std::string getMainArtist(metadb_handle_list_cref tracks)
{
// Don't look at too many tracks - this method should be quick but won't be if we don't limit ourselves.
static const t_size maxNumberOfTracksToConsider = 100;
// Keep track of the number of each artist name we encounter.
std::map<const char*, t_size> artists;
// For each track, increment the number of occurrences of its artist.
for(t_size i = 0; i < tracks.get_count() && i < maxNumberOfTracksToConsider; i++)
{
service_ptr_t<metadb_info_container> outInfo;
if(tracks[i]->get_async_info_ref(outInfo))
{
const file_info& fileInfo = outInfo->info();
const bool has_artist_tag = fileInfo.meta_exists("artist");
const bool has_album_artist_tag = fileInfo.meta_exists("album artist");
if(has_artist_tag || has_album_artist_tag)
{
const char * artist = has_artist_tag ? fileInfo.meta_get("artist", 0) : fileInfo.meta_get("album artist", 0);
++artists[artist];
}
}
}
// Find the artist that occurred the most.
t_size maxCount = 0;
const char* maxArtist = "";
for(auto iter = artists.begin(); iter != artists.end(); iter++)
{
if((iter->second) > maxCount)
{
maxCount = iter->second;
maxArtist = iter->first;
}
}
// We've kept the database locked this whole time because we're just storing char* in the map, not copying the strings.
return maxArtist;
}
示例12: calc_total_size
t_filesize metadb_handle_list_helper::calc_total_size(metadb_handle_list_cref p_list, bool skipUnknown) {
pfc::avltree_t< const char*, metadb::path_comparator > beenHere;
// metadb_handle_list list(p_list);
// list.sort_t(metadb::path_compare_metadb_handle);
t_filesize ret = 0;
t_size n, m = p_list.get_count();
for(n=0;n<m;n++) {
bool isNew;
metadb_handle_ptr h; p_list.get_item_ex(h, n);
beenHere.add_ex( h->get_path(), isNew);
if (isNew) {
t_filesize t = h->get_filesize();
if (t == filesize_invalid) {
if (!skipUnknown) return filesize_invalid;
} else {
ret += t;
}
}
}
return ret;
}
示例13: getMainArtist
virtual bool
context_get_display(
unsigned int index,
metadb_handle_list_cref tracks,
pfc::string_base& out,
unsigned int& displayflags,
const GUID& /*caller*/
)
{
switch(index)
{
case Items::GetArtistTopTracks:
{
const auto& mainArtist = getMainArtist(tracks);
const t_size stringLength = mainArtist.length();
if(stringLength > 0)
{
// We have found a main artist; set the display of the item to be of the form:
// "Artist's top tracks".
out = mainArtist.c_str();
// Grammar alert! Artists ending with "s" get just a "'" rather than "'s".
if(out[stringLength - 1] == 's')
{
out.add_string("' top tracks");
}
else
{
out.add_string("'s top tracks");
}
}
else
{
// Failed to find a main artist; return the normal, non-custom name for the item.
get_item_name(index, out);
}
return true;
}
case Items::GetSimilarTracks:
{
if(tracks.get_count() == 0)
{
displayflags = FLAG_DISABLED_GRAYED;
get_item_name(index, out);
}
else
{
out = "Get tracks similar to ";
out.add_string(getTitle(tracks.get_item(0)).c_str());
}
return true;
}
default:
{
// Nothing wants to customise the display of the item; let the regular name be displayed.
get_item_name(index, out);
return true;
}
}
}