functions.php:
function my_category_tag_cloud($args) {
$defaults = array(
'smallest' => 8, 'largest' => 22, 'unit' => 'pt', 'number' => 45,
'format' => 'flat', 'separator' => "\n", 'orderby' => 'name', 'order' => 'ASC',
'exclude' => '', 'include' => '', 'link' => 'view', 'taxonomy' => 'post_tag', 'echo' => true
);
$args = wp_parse_args( $args, $defaults );
global $wpdb;
$query = "
SELECT DISTINCT terms2.term_id as term_id, terms2.name as name, t2.count as count
FROM
$wpdb->posts as p1
LEFT JOIN $wpdb->term_relationships as r1 ON p1.ID = r1.object_ID
LEFT JOIN $wpdb->term_taxonomy as t1 ON r1.term_taxonomy_id = t1.term_taxonomy_id
LEFT JOIN $wpdb->terms as terms1 ON t1.term_id = terms1.term_id,
$wpdb->posts as p2
LEFT JOIN $wpdb->term_relationships as r2 ON p2.ID = r2.object_ID
LEFT JOIN $wpdb->term_taxonomy as t2 ON r2.term_taxonomy_id = t2.term_taxonomy_id
LEFT JOIN $wpdb->terms as terms2 ON t2.term_id = terms2.term_id
WHERE
t1.taxonomy = 'category' AND p1.post_status = 'publish' AND terms1.term_id = " . $args['cat'] . " AND
t2.taxonomy = 'post_tag' AND p2.post_status = 'publish'
AND p1.ID = p2.ID
";
$tags = $wpdb->get_results($query);
foreach ( $tags as $key => $tag ) {
if ( 'edit' == $args['link'] )
$link = get_edit_tag_link( $tag->term_id, $args['taxonomy'] );
else
$link = get_term_link( intval($tag->term_id), $args['taxonomy'] );
if ( is_wp_error( $link ) )
return false;
$tags[ $key ]->link = $link;
$tags[ $key ]->id = $tag->term_id;
}
$return = wp_generate_tag_cloud( $tags, $args );
$return = apply_filters( 'wp_tag_cloud', $return, $args );
if ( 'array' == $args['format'] || empty($args['echo']) )
return $return;
echo $return;
}
表示したいところで:
my_category_tag_cloud('cat=123'); // カテゴリーIDを指定
kzさま
とても長いコードで恐縮しております。
カテゴリーIDを自動で取得するために、こちらのサイト(ttp://blog.magical-remix.net/igalog/archives/99)を真似て、数行追加致しました。
foreach((get_the_category()) as $cat) {
$cat_id = $cat->cat_ID ;
break ;
}
$query = 'cat=' . $cat_id;
my_category_tag_cloud($query);
思い通りの動きをさせることが出来て嬉しいです。
どうもありがとうございました!
miracostaさん
その、Kzさんのコ-ドに追記されたものを、表示したいところへ呼び出すにはどう記述すればいいのでしょうか?初心者ゆえ初歩的な質問、ご寛恕ください。
現在、ウィジェットに「カテゴリ-」を設置していまして、ウィジェットスペ-スには作ったカテゴリ-が並んでいます。
ブログ閲覧者の方がAというカテゴリ-を選んだ時に、Aカテゴリ-の記事がたくさん羅列されるのですが、その画面上部に、Aカテゴリ-専用のタグクラウドを表示したいのです。もちろんA以外のBやC、Dのカテゴリ-も同様に、それぞれのカテゴリ-専用のタグクラウドが欲しいと思っており、なんとかしたいと思っていたところ、KZさん、miracostaさんの書き込みを発見いたしました。なにとぞご教授いただきたく、よろしくお願いいたします。