Crear o administrar nodo de forma SmartArt de PowerPoint en JavaScript
Agregar nodo SmartArt en presentación de PowerPoint usando JavaScript
Aspose.Slides for Node.js via Java ha proporcionado la API más simple para gestionar las formas SmartArt de la manera más fácil. El siguiente código de ejemplo ayudará a agregar un nodo y un nodo hijo dentro de la forma SmartArt.
- Cree una instancia de la clase Presentation y cargue la presentación con la forma SmartArt.
- Obtenga la referencia de la primera diapositiva usando su índice.
- Recorra cada forma dentro de la primera diapositiva.
- Verifique si la forma es del tipo SmartArt y convierta la forma seleccionada a SmartArt si es SmartArt.
- Agregue un nuevo nodo en la forma SmartArt NodeCollection y establezca el texto en TextFrame.
- Ahora, agregue un Child Node en el nodo SmartArt recién agregado y establezca el texto en TextFrame.
- Guarde la presentación.
// Cargar la presentación deseada
var pres = new aspose.slides.Presentation("SimpleSmartArt.pptx");
try {
// Recorrer cada forma dentro de la primera diapositiva
for (let i = 0; i < pres.getSlides().get_Item(0).getShapes().size(); i++) {
let shape = pres.getSlides().get_Item(0).getShapes().get_Item(i);
// Verificar si la forma es del tipo SmartArt
if (java.instanceOf(shape, "com.aspose.slides.SmartArt")) {
// Convertir la forma a SmartArt
var smart = shape;
// Añadir un nuevo nodo SmartArt
var TemNode = smart.getAllNodes().addNode();
// Añadir texto
TemNode.getTextFrame().setText("Test");
// Añadir un nuevo nodo hijo en el nodo padre. Se añadirá al final de la colección
var newNode = TemNode.getChildNodes().addNode();
// Añadir texto
newNode.getTextFrame().setText("New Node Added");
}
}
// Guardar la presentación
pres.save("AddSmartArtNode.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
Agregar nodo SmartArt en posición específica
En el siguiente código de ejemplo hemos explicado cómo agregar los nodos hijo pertenecientes a los nodos respectivos de la forma SmartArt en una posición particular.
- Cree una instancia de la clase Presentation.
- Obtenga la referencia de la primera diapositiva usando su índice.
- Agregue una forma SmartArt de tipo StackedList en la diapositiva accedida.
- Acceda al primer nodo en la forma SmartArt añadida.
- Ahora, agregue el Child Node para el Node seleccionado en la posición 2 y establezca su texto.
- Guarde la presentación.
// Creando una instancia de presentación
var pres = new aspose.slides.Presentation();
try {
// Acceder a la diapositiva de la presentación
var slide = pres.getSlides().get_Item(0);
// Agregar Smart Art IShape
var smart = slide.getShapes().addSmartArt(0, 0, 400, 400, aspose.slides.SmartArtLayoutType.StackedList);
// Accediendo al nodo SmartArt en el índice 0
var node = smart.getAllNodes().get_Item(0);
// Añadiendo nuevo nodo hijo en la posición 2 del nodo padre
var chNode = node.getChildNodes().addNodeByPosition(2);
// Agregar texto
chNode.getTextFrame().setText("Sample Text Added");
// Guardar presentación
pres.save("AddSmartArtNodeByPosition.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
Acceder al nodo SmartArt en presentación de PowerPoint usando JavaScript
El siguiente código de ejemplo ayudará a acceder a los nodos dentro de la forma SmartArt. Tenga en cuenta que no puede cambiar el LayoutType del SmartArt ya que es de solo lectura y solo se establece cuando se agrega la forma SmartArt.
- Cree una instancia de la clase Presentation y cargue la presentación con la forma SmartArt.
- Obtenga la referencia de la primera diapositiva usando su índice.
- Recorra cada forma dentro de la primera diapositiva.
- Verifique si la forma es del tipo SmartArt y convierta la forma seleccionada a SmartArt si es SmartArt.
- Recorra todos los Nodes dentro de la forma SmartArt.
- Acceda y muestre información como la posición del nodo SmartArt, nivel y texto.
// Instanciar la clase Presentation
var pres = new aspose.slides.Presentation("SmartArtShape.pptx");
try {
// Obtener la primera diapositiva
var slide = pres.getSlides().get_Item(0);
// Recorrer cada forma dentro de la primera diapositiva
for (let i = 0; i < slide.getShapes().size(); i++) {
let shape = slide.getShapes().get_Item(i);
// Verificar si la forma es del tipo SmartArt
if (java.instanceOf(shape, "com.aspose.slides.ISmartArt")) {
// Convertir la forma a SmartArt
var smart = shape;
// Recorrer todos los nodos dentro de SmartArt
for (var j = 0; j < smart.getAllNodes().size(); j++) {
// Accediendo al nodo SmartArt en el índice i
var node = smart.getAllNodes().get_Item(j);
// Imprimiendo los parámetros del nodo SmartArt
console.log(node.getTextFrame().getText() + " " + node.getLevel() + " " + node.getPosition());
}
}
}
} finally {
if (pres != null) {
pres.dispose();
}
}
Acceder al nodo hijo SmartArt
El siguiente código de ejemplo ayudará a acceder a los nodos hijo pertenecientes a los nodos respectivos de la forma SmartArt.
- Cree una instancia de la clase Presentation y cargue la presentación con la forma SmartArt.
- Obtenga la referencia de la primera diapositiva usando su índice.
- Recorra cada forma dentro de la primera diapositiva.
- Verifique si la forma es del tipo SmartArt y convierta la forma seleccionada a SmartArt si es SmartArt.
- Recorra todos los Nodes dentro de la forma SmartArt.
- Para cada [Node] de la forma SmartArt seleccionada, recorra todos los Child Nodes dentro del nodo particular.
- Acceda y muestre información como la posición, nivel y texto del [Child Node].
// Instanciar la clase Presentation
var pres = new aspose.slides.Presentation("AccessChildNodes.pptx");
try {
// Obtener la primera diapositiva
var slide = pres.getSlides().get_Item(0);
// Recorrer cada forma dentro de la primera diapositiva
for (let s = 0; s < slide.getShapes().size(); s++) {
let shape = slide.getShapes().get_Item(s);
// Verificar si la forma es del tipo SmartArt
if (java.instanceOf(shape, "com.aspose.slides.ISmartArt")) {
// Convertir la forma a SmartArt
var smart = shape;
// Recorrer todos los nodos dentro de SmartArt
for (var i = 0; i < smart.getAllNodes().size(); i++) {
// Accediendo al nodo SmartArt en el índice i
var node0 = smart.getAllNodes().get_Item(i);
// Recorriendo los nodos hijo en el nodo SmartArt en el índice i
for (var j = 0; j < node0.getChildNodes().size(); j++) {
// Accediendo al nodo hijo en el nodo SmartArt
var node = node0.getChildNodes().get_Item(j);
// Imprimiendo los parámetros del nodo hijo SmartArt
console.log("j = " + j + ", Text = " + node.getTextFrame().getText() + ", Level = " + node.getLevel() + ", Position = " + node.getPosition());
}
}
}
}
} finally {
if (pres != null) {
pres.dispose();
}
}
Acceder al nodo hijo SmartArt en posición específica
En este ejemplo, aprenderemos a acceder a los nodos hijo en una posición particular pertenecientes a los nodos respectivos de la forma SmartArt.
- Cree una instancia de la clase Presentation.
- Obtenga la referencia de la primera diapositiva usando su índice.
- Agregue una forma SmartArt de tipo StackedList.
- Acceda a la forma SmartArt añadida.
- Acceda al nodo en el índice 0 de la forma SmartArt accedida.
- Ahora, acceda al [Child Node] en la posición 1 del nodo SmartArt accedido utilizando el método get_Item().
- Acceda y muestre información como la posición, nivel y texto del [Child Node].
// Instanciar la presentación
var pres = new aspose.slides.Presentation();
try {
// Accediendo a la primera diapositiva
var slide = pres.getSlides().get_Item(0);
// Agregando la forma SmartArt en la primera diapositiva
var smart = slide.getShapes().addSmartArt(0, 0, 400, 400, aspose.slides.SmartArtLayoutType.StackedList);
// Accediendo al nodo SmartArt en el índice 0
var node = smart.getAllNodes().get_Item(0);
// Accediendo al nodo hijo en la posición 1 del nodo padre
var position = 1;
var chNode = node.getChildNodes().get_Item(position);
// Imprimiendo los parámetros del nodo hijo SmartArt
console.log("Text = " + chNode.getTextFrame().getText() + ", Level = " + chNode.getLevel() + ", Position = " + chNode.getPosition());
} finally {
if (pres != null) {
pres.dispose();
}
}
Eliminar nodo SmartArt en presentación de PowerPoint usando JavaScript
En este ejemplo, aprenderemos a eliminar los nodos dentro de la forma SmartArt.
- Cree una instancia de la clase Presentation y cargue la presentación con la forma SmartArt.
- Obtenga la referencia de la primera diapositiva usando su índice.
- Recorra cada forma dentro de la primera diapositiva.
- Verifique si la forma es del tipo SmartArt y convierta la forma seleccionada a SmartArt si es SmartArt.
- Verifique si el [SmartArt] tiene más de 0 nodos.
- Seleccione el nodo SmartArt a eliminar.
- Ahora, elimine el nodo seleccionado usando el método RemoveNode.
- Guarde la presentación.
// Cargar la presentación deseada
var pres = new aspose.slides.Presentation("AddSmartArtNode.pptx");
try {
// Recorrer cada forma dentro de la primera diapositiva
for (let i = 0; i < pres.getSlides().get_Item(0).getShapes().size(); i++) {
let shape = pres.getSlides().get_Item(0).getShapes().get_Item(i);
// Verificar si la forma es del tipo SmartArt
if (java.instanceOf(shape, "com.aspose.slides.ISmartArt")) {
// Convertir la forma a SmartArt
var smart = shape;
if (smart.getAllNodes().size() > 0) {
// Accediendo al nodo SmartArt en el índice 0
var node = smart.getAllNodes().get_Item(0);
// Eliminando el nodo seleccionado
smart.getAllNodes().removeNode(node);
}
}
}
// Guardar la presentación
pres.save("RemoveSmartArtNode.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
Eliminar nodo SmartArt en posición específica
En este ejemplo, aprenderemos a eliminar los nodos dentro de la forma SmartArt en una posición particular.
- Cree una instancia de la clase Presentation y cargue la presentación con la forma SmartArt.
- Obtenga la referencia de la primera diapositiva usando su índice.
- Recorra cada forma dentro de la primera diapositiva.
- Verifique si la forma es del tipo SmartArt y convierta la forma seleccionada a SmartArt si es SmartArt.
- Seleccione el nodo de la forma SmartArt en el índice 0.
- Ahora, verifique si el nodo SmartArt seleccionado tiene más de 2 nodos hijo.
- Ahora, elimine el nodo en la Posición 1 usando el método RemoveNode.
- Guarde la presentación.
// Cargar la presentación deseada
var pres = new aspose.slides.Presentation("AddSmartArtNode.pptx");
try {
// Recorrer cada forma dentro de la primera diapositiva
for (let i = 0; i < pres.getSlides().get_Item(0).getShapes().size(); i++) {
let shape = pres.getSlides().get_Item(0).getShapes().get_Item(i);
// Verificar si la forma es del tipo SmartArt
if (java.instanceOf(shape, "com.aspose.slides.SmartArt")) {
// Convertir la forma a SmartArt
var smart = shape;
if (smart.getAllNodes().size() > 0) {
// Accediendo al nodo SmartArt en el índice 0
var node = smart.getAllNodes().get_Item(0);
if (node.getChildNodes().size() >= 2) {
// Eliminando el nodo hijo en la posición 1
node.getChildNodes().removeNode(1);
}
}
}
}
// Guardar la presentación
pres.save("RemoveSmartArtNodeByPosition.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
Establecer posición personalizada para el nodo hijo en SmartArt
Ahora Aspose.Slides for Node.js via Java admite la configuración de las propiedades SmartArtShape X y Y. El fragmento de código a continuación muestra cómo establecer la posición, el tamaño y la rotación personalizados de SmartArtShape; tenga en cuenta que agregar nuevos nodos provoca un recálculo de las posiciones y tamaños de todos los nodos. Además, con la configuración de posición personalizada, el usuario puede establecer los nodos según sus requisitos.
// Instanciar la clase Presentation
var pres = new aspose.slides.Presentation("SimpleSmartArt.pptx");
try {
var smart = pres.getSlides().get_Item(0).getShapes().addSmartArt(20, 20, 600, 500, aspose.slides.SmartArtLayoutType.OrganizationChart);
// Mover la forma SmartArt a una nueva posición
var node = smart.getAllNodes().get_Item(1);
var shape = node.getShapes().get_Item(1);
shape.setX(shape.getX() + (shape.getWidth() * 2));
shape.setY(shape.getY() - (shape.getHeight() * 2));
// Cambiar los anchos de la forma SmartArt
node = smart.getAllNodes().get_Item(2);
shape = node.getShapes().get_Item(1);
shape.setWidth(shape.getWidth() + (shape.getWidth() * 2));
// Cambiar la altura de la forma SmartArt
node = smart.getAllNodes().get_Item(3);
shape = node.getShapes().get_Item(1);
shape.setHeight(shape.getHeight() + (shape.getHeight() * 2));
// Cambiar la rotación de la forma SmartArt
node = smart.getAllNodes().get_Item(4);
shape = node.getShapes().get_Item(1);
shape.setRotation(90);
pres.save("SmartArt.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
pres.dispose();
}
Verificar nodo Asistente
Usaremos la siguiente forma SmartArt de origen para nuestra investigación en diferentes secciones de este artículo.
![]() |
|---|
| Figura: Forma SmartArt de origen en la diapositiva |
En el siguiente código de ejemplo investigaremos cómo identificar Assistant Nodes en la colección de nodos SmartArt y modificarlos.
- Cree una instancia de la clase Presentation y cargue la presentación con la forma SmartArt.
- Obtenga la referencia de la segunda diapositiva usando su índice.
- Recorra cada forma dentro de la primera diapositiva.
- Verifique si la forma es del tipo SmartArt y convierta la forma seleccionada a SmartArt si es SmartArt.
- Recorra todos los nodos dentro de la forma SmartArt y verifique si son Assistant Nodes.
- Cambie el estado del Assistant Node a nodo normal.
- Guarde la presentación.
// Crear una instancia de presentación
var pres = new aspose.slides.Presentation("AddNodes.pptx");
try {
// Recorrer cada forma dentro de la primera diapositiva
for (let i = 0; i < pres.getSlides().get_Item(0).getShapes().size(); i++) {
let shape = pres.getSlides().get_Item(0).getShapes().get_Item(i);
// Verificar si la forma es de tipo SmartArt
if (java.instanceOf(shape, "com.aspose.slides.ISmartArt")) {
// Convertir la forma a SmartArt
var smart = shape;
// Recorrer todos los nodos de la forma SmartArt
for (var j = 0; j < smart.getAllNodes().size(); j++) {
var node = smart.getAllNodes().get_Item(j);
// Verificar si el nodo es un nodo Asistente
if (node.isAssistant()) {
// Establecer el nodo Asistente a false y convertirlo en nodo normal
node.isAssistant();
}
}
}
}
// Guardar la presentación
pres.save("ChangeAssitantNode.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
![]() |
|---|
| Figura: Nodos Asistente modificados en la forma SmartArt dentro de la diapositiva |
Establecer formato de relleno del nodo
Aspose.Slides for Node.js via Java permite agregar formas SmartArt personalizadas y establecer su formato de relleno. Este artículo explica cómo crear y acceder a formas SmartArt y establecer su formato de relleno usando Aspose.Slides for Node.js via Java.
- Cree una instancia de la clase Presentation.
- Obtenga la referencia de una diapositiva usando su índice.
- Agregue una forma SmartArt estableciendo su LayoutType.
- Establezca el FillFormat para los nodos de la forma SmartArt.
- Guarde la presentación modificada como un archivo PPTX.
// Instanciar la presentación
var pres = new aspose.slides.Presentation();
try {
// Accediendo a la diapositiva
var slide = pres.getSlides().get_Item(0);
// Agregar forma SmartArt y nodos
var chevron = slide.getShapes().addSmartArt(10, 10, 800, 60, aspose.slides.SmartArtLayoutType.ClosedChevronProcess);
var node = chevron.getAllNodes().addNode();
node.getTextFrame().setText("Some text");
// Configurar el color de relleno del nodo
for (let i = 0; i < node.getShapes().size(); i++) {
let item = node.getShapes().get_Item(i);
item.getFillFormat().setFillType(java.newByte(aspose.slides.FillType.Solid));
item.getFillFormat().getSolidFillColor().setColor(java.getStaticFieldValue("java.awt.Color", "RED"));
}
// Guardar la presentación
pres.save("TestSmart.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
Generar miniatura del nodo hijo SmartArt
Los desarrolladores pueden generar una miniatura del nodo hijo de un SmartArt siguiendo los pasos a continuación:
- Cree una instancia de la clase Presentation.
- Agregue SmartArt.
- Obtenga la referencia de un nodo usando su índice.
- Obtenga la imagen miniatura.
- Guarde la imagen miniatura en cualquier formato de imagen deseado.
// Instanciar la clase Presentation que representa el archivo PPTX
var pres = new aspose.slides.Presentation();
try {
// Agregar SmartArt
var smart = pres.getSlides().get_Item(0).getShapes().addSmartArt(10, 10, 400, 300, aspose.slides.SmartArtLayoutType.BasicCycle);
// Obtener la referencia de un nodo usando su índice
var node = smart.getNodes().get_Item(1);
// Obtener miniatura
var slideImage = node.getShapes().get_Item(0).getImage();
// Guardar miniatura
try {
slideImage.save("SmartArt_ChildNote_Thumbnail.png", aspose.slides.ImageFormat.Png);
} finally {
if (slideImage != null) {
slideImage.dispose();
}
}
} finally {
if (pres != null) {
pres.dispose();
}
}
FAQ
¿Se admite la animación de SmartArt?
Sí. SmartArt se trata como una forma normal, por lo que puede aplicar animaciones estándar (entrada, salida, énfasis, trayectorias de movimiento) y ajustar la sincronización. También puede animar formas dentro de los nodos SmartArt cuando sea necesario.
¿Cómo puedo localizar de forma fiable un SmartArt específico en una diapositiva si su ID interno es desconocido?
Asigne y busque por texto alternativo. Establecer un AltText distintivo en el SmartArt le permite encontrarlo sin depender de los identificadores internos.
¿Se preservará la apariencia del SmartArt al convertir la presentación a PDF?
Sí. Aspose.Slides renderiza SmartArt con alta fidelidad visual durante la exportación a PDF, preservando el diseño, los colores y los efectos.
¿Puedo extraer una imagen de todo el SmartArt (para vistas previas o informes)?
Sí. Puede renderizar una forma SmartArt a formatos raster o a SVG para salida vectorial escalable, lo que la hace adecuada para miniaturas, informes o uso web.

