Gestionar listas con viñetas y numeradas en presentaciones usando JavaScript
En Microsoft PowerPoint, puedes crear listas con viñetas y numeradas de la misma forma que lo haces en Word y otros editores de texto. Aspose.Slides for Node.js via Java también permite usar viñetas y números en las diapositivas de tus presentaciones.
¿Por qué usar listas con viñetas?
Las listas con viñetas te ayudan a organizar y presentar información de forma rápida y eficaz.
Ejemplo de lista con viñetas
En la mayoría de los casos, una lista con viñetas cumple estas tres funciones principales:
- atrae la atención de tus lectores o espectadores a información importante
- permite que tus lectores o espectadores escaneen fácilmente los puntos clave
- comunica y entrega detalles importantes de manera eficiente.
¿Por qué usar listas numeradas?
Las listas numeradas también ayudan a organizar y presentar información. Idealmente, deberías usar números (en lugar de viñetas) cuando el orden de las entradas (por ejemplo, paso 1, paso 2, etc.) es importante o cuando una entrada debe referenciarse (por ejemplo, ver paso 3).
Ejemplo de lista numerada
Este es un resumen de los pasos (del paso 1 al paso 15) en el procedimiento Creating Bullets a continuación:
- Crea una instancia de la clase Presentation.
- Realiza varias tareas (del paso 3 al paso 14).
- Guarda la presentación.
Crear viñetas
Este tema también forma parte de la serie de temas sobre la gestión de párrafos de texto. Esta página ilustrará cómo podemos gestionar viñetas de párrafo. Las viñetas son más útiles cuando algo debe describirse en pasos. Además, el texto se ve bien organizado al usar viñetas. Los párrafos con viñetas siempre son más fáciles de leer y comprender. Veremos cómo los desarrolladores pueden usar esta característica pequeña pero potente de Aspose.Slides for Node.js via Java. Sigue los pasos a continuación para gestionar las viñetas de párrafo usando Aspose.Slides for Node.js via Java:
- Crea una instancia de la clase Presentation.
- Accede a la diapositiva deseada en la colección de diapositivas usando el objeto Slide.
- Añade un AutoShape en la diapositiva seleccionada.
- Accede al TextFrame de la forma añadida.
- Elimina el párrafo predeterminado en el TextFrame.
- Crea la primera instancia de párrafo usando la clase Paragraph.
- Establece el tipo de viñeta del párrafo.
- Establece el tipo de viñeta a Symbol y define el carácter de viñeta.
- Establece el texto del párrafo.
- Establece la sangría del párrafo para fijar la viñeta.
- Establece el color de la viñeta.
- Establece la altura de las viñetas.
- Añade el párrafo creado en la colección de párrafos del TextFrame.
- Añade el segundo párrafo y repite el proceso indicado en los pasos 7 al 13.
- Guarda la presentación.
// Instanciar una clase Presentation que representa un archivo PPTX
var pres = new aspose.slides.Presentation();
try {
// Accediendo a la primera diapositiva
var slide = pres.getSlides().get_Item(0);
// Añadiendo y accediendo a AutoShape
var aShp = slide.getShapes().addAutoShape(aspose.slides.ShapeType.Rectangle, 200, 200, 400, 200);
// Accediendo al marco de texto del AutoShape creado
var txtFrm = aShp.getTextFrame();
// Eliminando el párrafo predeterminado existente
txtFrm.getParagraphs().removeAt(0);
// Creando un párrafo
var para = new aspose.slides.Paragraph();
// Configurando el estilo de viñeta y el símbolo del párrafo
para.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Symbol);
para.getParagraphFormat().getBullet().setChar(8226);
// Estableciendo el texto del párrafo
para.setText("Welcome to Aspose.Slides");
// Configurando la sangría de la viñeta
para.getParagraphFormat().setIndent(25);
// Configurando el color de la viñeta
para.getParagraphFormat().getBullet().getColor().setColorType(aspose.slides.ColorType.RGB);
para.getParagraphFormat().getBullet().getColor().setColor(java.getStaticFieldValue("java.awt.Color", "BLACK"));
// establecer IsBulletHardColor a true para usar un color de viñeta propio
para.getParagraphFormat().getBullet().isBulletHardColor();
// Configurando la altura de la viñeta
para.getParagraphFormat().getBullet().setHeight(100);
// Añadiendo el párrafo al marco de texto
txtFrm.getParagraphs().add(para);
// guardando la presentación como archivo PPTX
pres.save("Bullet.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
pres.dispose();
}
Crear viñetas con imagen
Aspose.Slides for Node.js via Java permite cambiar las viñetas en las listas con viñetas. Puedes sustituir las viñetas por símbolos personalizados o imágenes. Si deseas añadir interés visual a una lista o atraer aún más la atención a las entradas de una lista, puedes usar tu propia imagen como viñeta.
Idealmente, si pretendes sustituir el símbolo de viñeta estándar por una imagen, deberías seleccionar una imagen gráfica simple con fondo transparente. Estas imágenes funcionan mejor como símbolos de viñeta personalizados.
En cualquier caso, la imagen que elijas se reducirá a un tamaño muy pequeño, por lo que recomendamos encarecidamente que selecciones una imagen que se vea bien (como sustituto del símbolo de viñeta) en una lista.
Para crear una viñeta con imagen, sigue estos pasos:
- Crea una instancia de la clase Presentation
- Accede a la diapositiva deseada en la colección de diapositivas usando el objeto Slide
- Añade un autoshape en la diapositiva seleccionada
- Accede al TextFrame de la forma añadida
- Elimina el párrafo predeterminado en el TextFrame
- Crea la primera instancia de párrafo usando la clase Paragraph
- Carga la imagen desde disco en PPImage
- Establece el tipo de viñeta a Picture y asigna la imagen
- Establece el texto del párrafo
- Establece la sangría del párrafo para fijar la viñeta
- Establece el color de la viñeta
- Establece la altura de las viñetas
- Añade el párrafo creado en la colección de párrafos del TextFrame
- Añade el segundo párrafo y repite el proceso descrito en los pasos anteriores
- Guarda la presentación
var pres = new aspose.slides.Presentation();
try {
// Accediendo a la primera diapositiva
var slide = pres.getSlides().get_Item(0);
// Instanciar la imagen para viñetas
var picture;
var image = aspose.slides.Images.fromFile("asp1.jpg");
try {
picture = pres.getImages().addImage(image);
} finally {
if (image != null) {
image.dispose();
}
}
// Añadiendo y accediendo a AutoShape
var aShp = slide.getShapes().addAutoShape(aspose.slides.ShapeType.Rectangle, 200, 200, 400, 200);
// Accediendo al marco de texto del AutoShape creado
var txtFrm = aShp.getTextFrame();
// Eliminando el párrafo predeterminado existente
txtFrm.getParagraphs().removeAt(0);
// Creando un nuevo párrafo
var para = new aspose.slides.Paragraph();
para.setText("Welcome to Aspose.Slides");
// Estableciendo el estilo de viñeta del párrafo y la imagen
para.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Picture);
para.getParagraphFormat().getBullet().getPicture().setImage(picture);
// Estableciendo la altura de la viñeta
para.getParagraphFormat().getBullet().setHeight(100);
// Añadiendo el párrafo al marco de texto
txtFrm.getParagraphs().add(para);
// Guardando la presentación como archivo PPTX
pres.save("Bullet.pptx", aspose.slides.SaveFormat.Pptx);
} catch (e) {console.log(e);
} finally {
if (pres != null) {
pres.dispose();
}
}
Crear viñetas multinivel
Para crear una lista con viñetas que contenga elementos en diferentes niveles — listas adicionales bajo la lista principal — sigue estos pasos:
- Crea una instancia de la clase [Presentation].
- Accede a la diapositiva deseada en la colección de diapositivas usando el objeto [Slide].
- Añade un autoshape en la diapositiva seleccionada.
- Accede al [TextFrame] de la forma añadida.
- Elimina el párrafo predeterminado en el [TextFrame].
- Crea la primera instancia de párrafo usando la clase Paragraph y con la profundidad establecida en 0.
- Crea la segunda instancia de párrafo usando la clase Paragraph y con la profundidad establecida en 1.
- Crea la tercera instancia de párrafo usando la clase Paragraph y con la profundidad establecida en 2.
- Crea la cuarta instancia de párrafo usando la clase Paragraph y con la profundidad establecida en 3.
- Añade los párrafos creados a la colección de párrafos del [TextFrame].
- Guarda la presentación.
// Instanciar una clase Presentation que representa un archivo PPTX
var pres = new aspose.slides.Presentation();
try {
// Accediendo a la primera diapositiva
var slide = pres.getSlides().get_Item(0);
// Añadiendo y accediendo a AutoShape
var aShp = slide.getShapes().addAutoShape(aspose.slides.ShapeType.Rectangle, 200, 200, 400, 200);
// Accediendo al marco de texto del AutoShape creado
var txtFrm = aShp.getTextFrame();
// Eliminando el párrafo predeterminado existente
txtFrm.getParagraphs().clear();
// Creando el primer párrafo
var para1 = new aspose.slides.Paragraph();
// Configurando el estilo de viñeta y símbolo del párrafo
para1.setText("Content");
para1.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Symbol);
para1.getParagraphFormat().getBullet().setChar(8226);
para1.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(java.newByte(aspose.slides.FillType.Solid));
para1.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(java.getStaticFieldValue("java.awt.Color", "BLACK"));
// Configurando el nivel de viñeta
para1.getParagraphFormat().setDepth(0);
// Creando el segundo párrafo
var para2 = new aspose.slides.Paragraph();
// Configurando el estilo de viñeta y símbolo del párrafo
para2.setText("Second level");
para2.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Symbol);
para2.getParagraphFormat().getBullet().setChar('-');
para2.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(java.newByte(aspose.slides.FillType.Solid));
para2.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(java.getStaticFieldValue("java.awt.Color", "BLACK"));
// Configurando el nivel de viñeta
para2.getParagraphFormat().setDepth(1);
// Creando el tercer párrafo
var para3 = new aspose.slides.Paragraph();
// Configurando el estilo de viñeta y símbolo del párrafo
para3.setText("Third level");
para3.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Symbol);
para3.getParagraphFormat().getBullet().setChar(8226);
para3.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(java.newByte(aspose.slides.FillType.Solid));
para3.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(java.getStaticFieldValue("java.awt.Color", "BLACK"));
// Configurando el nivel de viñeta
para3.getParagraphFormat().setDepth(2);
// Creando el cuarto párrafo
var para4 = new aspose.slides.Paragraph();
// Configurando el estilo de viñeta y símbolo del párrafo
para4.setText("Fourth Level");
para4.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Symbol);
para4.getParagraphFormat().getBullet().setChar('-');
para4.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(java.newByte(aspose.slides.FillType.Solid));
para4.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(java.getStaticFieldValue("java.awt.Color", "BLACK"));
// Configurando el nivel de viñeta
para4.getParagraphFormat().setDepth(3);
// Añadiendo el párrafo al marco de texto
txtFrm.getParagraphs().add(para1);
txtFrm.getParagraphs().add(para2);
txtFrm.getParagraphs().add(para3);
txtFrm.getParagraphs().add(para4);
// Guardando la presentación como un archivo PPTX
pres.save("MultilevelBullet.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
Crear lista numerada personalizada
Aspose.Slides for Node.js via Java proporciona una API simple para gestionar párrafos con formatos de número personalizados. Para añadir una lista numerada personalizada en un párrafo, sigue los pasos a continuación:
- Crea una instancia de la clase [Presentation].
- Accede a la diapositiva deseada en la colección de diapositivas usando el objeto [Slide].
- Añade un autoshape en la diapositiva seleccionada.
- Accede al [TextFrame] de la forma añadida.
- Elimina el párrafo predeterminado en el [TextFrame].
- Crea la primera instancia de párrafo usando la clase Paragraph y establece NumberedBulletStartWith en 2
- Crea la segunda instancia de párrafo usando la clase Paragraph y establece NumberedBulletStartWith en 3
- Crea la tercera instancia de párrafo usando la clase Paragraph y establece NumberedBulletStartWith en 7
- Añade los párrafos creados a la colección de párrafos del [TextFrame].
- Guarda la presentación.
// Instanciar una clase Presentation que representa un archivo PPTX
var pres = new aspose.slides.Presentation();
try {
// Accediendo a la primera diapositiva
var slide = pres.getSlides().get_Item(0);
// Añadiendo y accediendo a AutoShape
var aShp = slide.getShapes().addAutoShape(aspose.slides.ShapeType.Rectangle, 200, 200, 400, 200);
// Accediendo al marco de texto del AutoShape creado
var txtFrm = aShp.addTextFrame("");
// Eliminando el párrafo predeterminado existente
txtFrm.getParagraphs().clear();
// Primera lista
var paragraph1 = new aspose.slides.Paragraph();
paragraph1.setText("bullet 2");
paragraph1.getParagraphFormat().setDepth(4);
paragraph1.getParagraphFormat().getBullet().setNumberedBulletStartWith(2);
paragraph1.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Numbered);
txtFrm.getParagraphs().add(paragraph1);
var paragraph2 = new aspose.slides.Paragraph();
paragraph2.setText("bullet 3");
paragraph2.getParagraphFormat().setDepth(4);
paragraph2.getParagraphFormat().getBullet().setNumberedBulletStartWith(3);
paragraph2.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Numbered);
txtFrm.getParagraphs().add(paragraph2);
// Segunda lista
var paragraph5 = new aspose.slides.Paragraph();
paragraph5.setText("bullet 5");
paragraph5.getParagraphFormat().setDepth(4);
paragraph5.getParagraphFormat().getBullet().setNumberedBulletStartWith(5);
paragraph5.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Numbered);
txtFrm.getParagraphs().add(paragraph5);
pres.save(resourcesOutputPath + "SetCustomBulletsNumber-slides.pptx.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
Preguntas frecuentes
¿Se pueden exportar las listas con viñetas y numeradas creadas con Aspose.Slides a otros formatos como PDF o imágenes?
Sí, Aspose.Slides conserva completamente el formato y la estructura de las listas con viñetas y numeradas cuando las presentaciones se exportan a formatos como PDF, imágenes y otros, garantizando resultados coherentes.
¿Es posible importar listas con viñetas o numeradas de presentaciones existentes?
Sí, Aspose.Slides permite importar y editar listas con viñetas o numeradas de presentaciones existentes conservando su formato y apariencia originales.
¿Aspose.Slides admite listas con viñetas y numeradas en presentaciones creadas en varios idiomas?
Sí, Aspose.Slides admite plenamente presentaciones multilingües, permitiendo crear listas con viñetas y numeradas en cualquier idioma, incluido el uso de caracteres especiales o no latinos.