renderować lub drukować obraz w drupal 7 node.tpl?


16

Próbuję utworzyć motyw węzła za pomocą tpl, a kiedy próbowałem wydrukować obraz, nie mogę znaleźć ścieżki obrazu jak w d6 .. jaką funkcję muszę wywołać, aby poprawnie wyprowadzić obraz .. Mam na myśli coś takiego jak theme ('')?

Array
(
    [und] => Array
        (
            [0] => Array
                (
                    [fid] => 13
                    [alt] => 
                    [title] => 
                    [width] => 416
                    [height] => 335
                    [uid] => 1
                    [filename] => Capture2.PNG
                    [uri] => public://Capture2.PNG
                    [filemime] => image/png
                    [filesize] => 215377
                    [status] => 1
                    [timestamp] => 1346837738
                    [rdf_mapping] => Array
                        (
                        )

                )

        )

)

Odpowiedzi:


33
<?php print render($content['field_image']); ?>

Jeśli chcesz zmienić sposób wyświetlania obrazu (wymiary, łącze itp.), Ustaw je na karcie Zarządzaj wyświetlaniem w ustawieniach typu węzła.

Możesz również wykonać wstępne ustawienie pamięci obrazu:

<?php
print theme('image_style', array('path' => $node->field_image[LANGUAGE_NONE][0]['uri'], 'style_name' => [STYLE NAME]));
?>

Ale to nie jest zalecany sposób!

jeśli chcesz zbudować URL z URI,

<img src="<?php print file_create_url($node->field_image[LANGUAGE_NONE][0]['uri']); ?>" />

dzięki, twoja odpowiedź obejmuje wszystkie rzeczy. Powinno to być w dokumentacji drupal.org :)
Serjas

Zawsze dobrym pomysłem jest użycie LANGUAGE_NONE zamiast „und”
qasimzee

Wiem, że biję martwego konia, ale jeśli podejmiesz drugie podejście, jak możesz zapewnić, że nie uzyskasz wyniku 404?
Cameron Kilgore,

3

Osoby korzystające z modułu file_entity (być może z modułem media ) mogą się zastanawiać, jak programowo renderować pliki / obrazy:

$image = (object) $node->field_image[ LANGUAGE_NONE ][0];
$image_entity = file_view($image, "summary");
echo drupal_render($image_entity);

Gdzie „field_image” to nazwa pola, a „podsumowanie” to tryb widoku.


działa dla mnie, ale musiałem ponownie ustawić styl na $ image_entity ['file'] ['# style_name'] ..
rémy

Nie powinieneś kodować na stałe klucza językowego.
AlxVallejo

1

Jeśli chcesz po prostu renderować obraz z ustawionym stylem obrazu dla tego obrazu na ekranie zarządzania: Po prostu wpisz <?php print_render($content['field_image']) ?>

Jeśli chcesz wyświetlić obraz z dowolnym innym stylem obrazu, WSPIERAJĄ: „Sales_album”, a następnie wpisz:

list($albumImage) = field_get_items('node', $album, 'uc_product_image');

$albumImageUrl = file_create_url($albumImage['uri']);

$style_array = array('path' => $albumImage['uri'], 'style_name' => 'sales_album');

$render_album_image = theme('image_style', $style_array);

print $render_album_image;

1

Podczas korzystania z modułu polowego stwierdziłem, że było to lepsze:

na stronie - yourcontenttype.tpl.php:

<?php
  $this_field_image = field_view_field('node',$node,'field_image');
  print render($this_field_image);?>
?>

użycie field_view_field () zapewnia dodatkowe korzyści, dzięki którym można ustawić szereg ustawień wyświetlania:

<?php
  $hide_labels = array('label'=>'hidden');
  $this_field_image = field_view_field('node',$node,'field_image', $hide_labels);
  print render($this_field_image);?>
?>

https://api.drupal.org/api/drupal/modules%21field%21field.module/function/field_view_field/7.x


0
$img_url = $node->field_name['und'][$i]['uri'];
print image_style_url("style_name", $img_url);

$ijest w przypadku, gdy masz wiele obrazów do wyświetlenia. Możesz użyć pętli for, takiej jak:

for($i=0;$i < $imageCount; $i++) { /*the above code*/ }

i $imageCountjest zasadniczo zadeklarowany powyżej dla pętli jako

$images = array();<br>
$imageCount= count($node->field_image['und']);

Mam nadzieję że to pomoże!

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.