メディアのアップロードでデフォルトで選択されている画像サイズを作成する方法-WP v3.5


12

私と一緒に。Media upload popup pageでデフォルトでカスタム画像サイズを選択したいです。Wordpress v3.4.2以前では、このエレガントなコードは問題なく機能していました。

function my_insert_custom_image_sizes( $sizes ) {
    // get the custom image sizes
    global $_wp_additional_image_sizes;
    // if there are none, just return the built-in sizes
    if ( empty( $_wp_additional_image_sizes ) )
        return $sizes;

    // add all the custom sizes to the built-in sizes
    foreach ( $_wp_additional_image_sizes as $id => $data ) {
        // take the size ID (e.g., 'my-name'), replace hyphens with spaces,
        // and capitalise the first letter of each word
        if ( !isset($sizes[$id]) )
            $sizes[$id] = ucfirst( str_replace( '-', ' ', $id ) );
    }

    return $sizes;
}


// Which custom image size selected by default
function my_set_default_image_size () { 
     return 'custom-image-size-2';
}


function custom_image_setup () {
    add_theme_support( 'post-thumbnails' );
    add_image_size( 'custom-image-size-1', 160, 9999 ); //  columned
    add_image_size( 'custom-image-size-2', 300, 9999 ); //  medium
    add_image_size( 'custom-image-size-3', 578, 190, true ); //  cropped
    add_filter( 'image_size_names_choose', 'my_insert_custom_image_sizes' );
    add_filter( 'pre_option_image_default_size', 'my_set_default_image_size' );
}

add_action( 'after_setup_theme', 'custom_image_setup' );

そのためmy_insert_custom_image_sizes、カスタム画像をメディアページに追加my_set_default_image_sizeし、custom-image-size-2サイズを選択する必要があります。このコードは、Wordpress 3.5バージョンでの動作を停止しました。v3.5でこれを達成する方法を知っていますか?


この直接あなたの質問に答えるが、あるいない種類の関連は次のとおりです。stackoverflow.com/questions/13936080/...
janw

回答:


2

これを試してください。あなたのADD_FILTER()の第二引数は、リターンを経由して現在のオプションに影響を与えることを、関数です。

function theme_default_image_size() {
    return 'custom-image-size-2';
}
add_filter( 'pre_option_image_default_size', 'theme_default_image_size' );

pre_update_option _ {$ option}フィルターを調べて値を1回更新することもできます。そのため、毎回このフィルターを実行する必要はありません(0.01を節約できますが、それでも節約できます!)。

または古き良きupdate_option()

update_option( 'image_default_size', 'custom-image-size-2' );

0

関数をテーマのfunctions.phpファイルに追加します。

if ( function_exists( 'add_theme_support' ) ) {
    add_theme_support( 'post-thumbnails' );
        set_post_thumbnail_size( 150, 150 ); // default Post Thumbnail dimensions   
}


function custom_image_setup () {

        add_theme_support('post-thumbnails');
        set_post_thumbnail_size(640,320);

    add_image_size( 'custom-image-size-1', 180, 9999 ); //  columned
    add_image_size( 'custom-image-size-2', 350, 9999 ); //  medium
    add_image_size( 'custom-image-size-3', 600, 250, true ); //  cropped

    add_filter( 'image_size_names_choose', 'theme_custom_image_sizes' );
    add_filter( 'pre_option_image_default_size', 'theme_default_image_size' );
}


if ( function_exists( 'add_image_size' ) ) { 
    add_image_size( 'category-thumb', 300, 9999 ); //300 pixels wide (and unlimited height)
    add_image_size( 'homepage-thumb', 220, 180, true ); //(cropped)
}

テーマのテンプレートファイル内での新しい画像サイズの使用。

if ( has_post_thumbnail() ) { the_post_thumbnail( 'category-thumb' ); }
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.