A child theme is definitely the way to go for the reason you outlined: upgradability. To start with, here is the documentation for creating child themes: http://codex.wordpress.org/Child_Themes
You’ll want to create the child theme directory and edit the style.css
file as described in the Child Theme documentation link above. After that, simply copy the header.php
file from the twentyten
directory into the directory and modify it to include the Flash element you have. By copying the header.php
to a child theme, it will override the parent theme’s version and be preserved after an update to the parent theme.
This is the block you want to edit, as it creates the header image:
<?php
// Check if this is a post or page, if it has a thumbnail, and if it's a big one
if ( is_singular() && current_theme_supports( 'post-thumbnails' ) &&
has_post_thumbnail( $post->ID ) &&
( /* $src, $width, $height */ $image = wp_get_attachment_image_src( get_post_thumbnail_id( $post->ID ), 'post-thumbnail' ) ) &&
$image[1] >= HEADER_IMAGE_WIDTH ) :
// Houston, we have a new header image!
echo get_the_post_thumbnail( $post->ID );
elseif ( get_header_image() ) : ?>
<img src="https://wordpress.stackexchange.com/questions/13133/<?php header_image(); ?>" width="<?php echo HEADER_IMAGE_WIDTH; ?>" height="<?php echo HEADER_IMAGE_HEIGHT; ?>" alt="" />
<?php endif; ?>
I would just delete that entire PHP block, and replace it with the <object>
code for your flash element. You’ll want to make sure the flash element is exactly 940 pixels across, though, or it might look strange/break the design.
The header image PHP block is located on line 68 of my header.php
(in the WordPress 3.1 twentyten theme), and it’s located directly below the following:
<div id="site-description"><?php bloginfo( 'description' ); ?></div>
Note that this isn’t foolproof. If the twentyten theme gets updated in the future and contains changes you would like to have in the child theme they won’t appear here. However, to add a hook which replaces the image header with a Flash one would require modifying the base theme’s header.php… a bit of a catch 22. In practice this shouldn’t be much of an issue, though. It’s also the best way in WordPress to handle this sort of thing.
For reference, here are the changes to the file on its Trac page.